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Z DMA OD JAPONII 


Wprawdzie mamy wakacje, ale 
przecież wszystko co piękne , szybko 
się kończy Dlatego proponuję kilka 
refleksji na temat szkoły — me naszej 
jednak, tylko japońskiej. Otóż rów¬ 
nież ją ostatnio zaczęto głośno kryty¬ 
kować — za to, iż nie przygotowuje 
właściwych kadr dla gospodarki na¬ 
rodowej, W tym kontekście zarzuca 
się tamtejszym władzom oświatowym 
niedociągnięcia w zakresie kompute¬ 
ryzacji procesu dydaktycznego Są to 
oczywiście zarzuty formułowane na 
zupełnie innym poziomie\ niż w Pols¬ 
ce 

W marcu 1988 roku w 24 692 pań¬ 
stwowych szkołach podstawowych w 
Japonii, do których uczęszczają ucz¬ 
niowie klas od pierwszej do szóstej 
znajdowały się 9523 komputery W 
tym czasie w 14.746 pełnych i niepeł¬ 
nych szkołach średnich, do których 
uczęszczają uczniowie klas od siód¬ 
mej do dwunastej, było na stanie 
90 619 komputerów. 

Widać z powyższego, że podstawo¬ 
wa masa kmputerów dydaktycznych 
skoncentrowana jest na razie w Japo¬ 
nii w szkołach średnich, do których 
uczęszczają uczniowie w najlepszym 
„komputerowym” wieku 15—17 lat. 
Według danych z marca 1988 aż w 
93,7 proc. tych szkół znajdowały się 
komputery do celów dydaktycznych 
Na każdą szkołę przypadało statysty¬ 
cznie osiemnaście komputerów 

Efektem krytyki poziomu szkolnej 
edukacji informatycznej była rewizja 
planów nauczania i programów wy¬ 
posażenia szkół w urządzenia elektro¬ 
nicznej techniki obliczeniowej. Zakła¬ 
da się, że poczynając od roku 1993 
nauczanie podstaw informatyki bę¬ 
dzie się rozpoczynać już w szkołach 
podstawowych. 

Aby przygotować się do tych no¬ 
wych zadań, w wybranych szkołach 
podstawowych Japonii już obecnie 
uruchomiono eksperymentalne centra 
nauczające podstaw programowania i 
korzystania z komputerów Na przy¬ 
kład szkoła podstawowa w miejsco¬ 
wości Kasiwa (prefektura Tiba) otrzy¬ 
mała 47 komputerów osobistych a 
wszyscy nauczyciele znają podstawy 


programowania i obsługi kompute¬ 
rów. 

Jak twierdzi dyrektor tej szkoły, Iu- 
dzo Mera, jego uczniowie — dzieci w 
wieku od 6 do 11 lat — me mają lęku i 
jakichkolwiek zahamowań posługi¬ 
wania się tą nowoczesną techniką 
„Uczniowie posługują się kompute¬ 
rem tak samo jak ołówkiem i kredka¬ 
mi” — mówi z zachwytem. Czyli 
zupełnie jak u nas, co jeszcze raz po¬ 
twierdza, ze świat jest mały, a prawi¬ 
dłowości związane z korzystaniem z 
nowoczesnej techniki przejawiają się 
tak samo pod każdą szerokością i dłu¬ 
gością geograficzną 

Polskim szkołom (średnim) daleko 
jest oczywfiscie do takiego poziomu 
nasycenia komputerami jak w Japo¬ 
nii. Niemniej jednak sprzęt do na¬ 
szych szkół systematycznie trafia i to 
me tylko w dużych miastach, ale rów¬ 
nież i w terenie, gdzie coraz częściej 
można spotkać porządnie wyposażone 
pracownie informatyczne Problemem 
zaczyna byc teraz właschce tego 
sprzętu wykorzystanie. 

Na razie szkolne nauczanie infor¬ 
matyki odbywa się bardzo chaotycz¬ 
nie, w zależności od osobistych pasji i 
umiejętności nauczycieli, którym 
przydzielono „nauczanie informaty¬ 
ki”. Za mało jest natomiast materia¬ 
łów dydaktycznych, specjalnie przy¬ 
gotowanych do tego celu programów, 
literatury itp 

Nie sądzę, aby potrafiono rozwiązać 
ten problem centralnie — bo w ogóle z 
centralizmem, me tylko w nauczaniu 
informatyki — jakoś nam ostatnio nie 
wychodzi. Dlatego szansę na poprawę 
sytuacji należy widzieć w szerokim 
rozwoju małych firm software'owych. 
Aby to jednak nastąpiło — warto po¬ 
myśleć o zapewnieniu im korzystnych 
warunków podatkowych. Te „straty” 
na pewno nam się już niedługo z na¬ 
wiązką zwrócą! 

A piszę o tym już teraz , w wakacje, 
gdyż to właśnie teraz decyduje się jak 
będzie wyglądał nadchodzący rok 
szkolny. Szkoda byłoby go znowu 
stracie! 

Waldemar Siwiński 


ZA MIESIĄC: 


• NARODZINY ROZRYWKI, 
czyli jak powstały gry kom¬ 
puterowe 

• ŻABIE ZAWODY dla przed¬ 
szkolaków 

• gry: Terramex, Captain Blood 
i Steel Thunder 

• grafika wektorowa 
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• TRZY KANAŁY w muzyce na 
SPECTRUM 

• OXFORD PASCAL na Com- 
modore 

• polskie znaki na ploterze 
SONY 

• co jest trudne, co jest proste 
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W kwietniu 1726 roku na Jamajce kapitan Gre- 
en z Bristolu zaokrętował w charakterze bosma¬ 
na na statku „Elizabeth” niejakiego Wiliama 
Fly’a. Fly wśliznął się na statek z kilku kamrata¬ 
mi znanymi z gotowości do każdego nikczemne¬ 
go czynu. Postanowił bowiem zamordować ka¬ 
pitana i pierwszego oficera aby samemu objąć 
dowodztwo i puścić się na piraterię. 


U wybrzeży Gwinei nędznicy pochwycili 
Greena i wyrzucili go za burtę. Po czym 
podnieśli na maszt czarną flagę i poczęli 
łupić statki spotkane na morzu 

Pojmano ich niedaleko Bostonu Fly zo¬ 
stał powieszony w łańcuchach u wejścia 
do przystani w tym mieście Krótkie było 
panowanie tego zakamieniałego w zbrodni 
łotra, któremu brakowało tylko kunsztu i 
sił, zęby dorównać słynnym infamisom, 
pladze mórz. 

A DZIŚ? 

Oczywiście są piraci morscy, ale to nie 
oni nas interesują Choć ich metody budzą 
odrazę i zasługują na podobne traktowanie 
jak trzysta lat temu 

Są tez inni. Wykształceni, inteligentni, 

posiadający znaczne dochody i nie oba¬ 
wiający się przyszłości — przynajmniej w 
Polsce 

To piram komputerowi Czerpiący zyski 

ze sprzedaży masowo powielanych pro¬ 
gramów Proceder ten jest możliwy, po¬ 
nieważ w naszym kraju me ma ochrony 
prawnej oprogramowania 

Fragment stanowiska Pol¬ 
skiego Towarzystwa Informa¬ 
tycznego w sprawie ochrony 
prawnej programów kompute¬ 
rowych sytuacja, w której 
można za darmo otrzymać ko¬ 
pie programów , stwarza społe¬ 
czne przekonanie, ze oprogra¬ 
mowanie nic nie kosztuje lub 


kosztuje niewiele To przeko¬ 
nanie jest błędne i może mieć 
poważne skutki dla podejmo¬ 
wania decyzji gospodarczych. 

Ich owocnej działalności zawdzięczamy 
powszechne w środowisku użytkowników 
przekonanie, że komputer jest wszystkim, 
a program niczym Można go przecież na¬ 
być za cenę niewsoółmierme niższą od 
ceny sprzętu 

Oferty handlarzy giełdowych — 300- 
400 złotych za jeden program na „Spec¬ 
trum" czy ogłoszenia prasowe licznych 
„Studiów komputerowych” proponują¬ 
cych „gry, programy użytkowe, literatu¬ 
rę .. i co piąty program bezpłatnie” — po¬ 
twierdzają tę tezę 

Pewien zachodni biznesmen posiadają¬ 
cy udziały w jednej z firm sprzedających 
na polskim rynku sprzęt komputerowy po 
odw edzeniu giełdy tak skomentował to, 
co zobaczył: „ Nie! W tym kraju nie sprze¬ 
dam ani jednego programu 

Identyczną zasadę wyznają rodzimi pro¬ 
gramiści. 

...kopiowanie na szeroką 
skalę oprogramowania zagra¬ 
nicznego bez zgody i woli pro¬ 
ducentów stanowi łamanie za¬ 
sad przyjętych w obrocie w ich 
krajach i jest poważną barierą 
dla rozwoju prawidłowych sto¬ 
sunków handlowych z tymi 
producentami 

Zyski ze sprzedaży oprogramowania są 
w skali światowej znacznie większe od 


tych ze sprzedaży sprzętu komputerowe¬ 
go 

Mimo to nie opłaca się pisanie progra¬ 
mów dla polskiego użytkownika. Z góry 
wiadomo, ze zysku me będzie. Program 
albo zostanie skopiowany i odsprzedany 
dalej, albo po prostu „puszczony” po zna¬ 
jomych. 

Stan ten hamuje rozwój rodzimego 
przemysłu softwarowego. Nie sposob wy¬ 
obrazić sobie firmy pragnącej wejść ze 
swoim towarem na zachodni rynek, jeśli w 
produkcji posługuje się ona kradzionym 
oprogramowaniem narzędziowym Nikt z 
mmi me będzie handlował. Nie kupuje się 
u pasera. 

Podobna sytuacja może spotkać przed¬ 
siębiorstwa posługujące się „pirackim’ 5 
oprogramowaniem w zupełnie innych ce¬ 
lach. 

O tym jak skuteczne mogą być tego ro¬ 
dzaju sankcje, mech przekona nas przy¬ 
kład Brazylii 

Amerykańskie korporacje handlowe os¬ 
karżyły firmy brazylijskie, eksportujące do 
USA kawę o posług wanie się kradzionym 
oprogramowaniem A bez komputerów me 
sposób obecnie prowadź ć poważnych in¬ 
teresów 

Brazylijczycy zareagowali błyskawicznie 
na spadek zainteresowania kawą Nie do¬ 
syć, ze wykupili prawa użytkowania odpo¬ 
wiednich programów, to dodatkowo wpro 

wadzili u siebie surowe przepisy chronią¬ 
ce producentów oorogramowan a. 

Bill Gates, szef największej na świecie 

firmy softwarowej M crosoft powiedział w 
jednym z wywiadów 

„ Komputer kupuje się raz na cztery lata, 
a nasze programy trzeba kupować stale 
Bez nich twój sprzęt staje się kupę zło¬ 
mu". 

ILE KOSZTUJE 
PROGRAM? 

Wystarczy sięgnąć do amerykańskiego 
miesięcznika „BYTE ” aby przekonać się, 
że me są to małe kwoty. Oto kilka przykła¬ 
dów z marca br 


DBase III Plus ..... 433 $ 

Lotus 1-2-3.295 $ 

Ventura Publisher 2.0 470$ 

Wordstar 2000 +. 205 $ 

Turbo Pascal 4.0 .... 58 $ 

To są ceny profesjonalnego oprogramo¬ 
wania. Miłośnikom gier wystarczają mniej¬ 
sze pieniądze. 

Defender of the Crown ... .... 37.99 $ 

King of Chicago . 37 99 $ 

Sub Battie. 27 99 $ 

King Quest IV .... .. 35 99 $ 

Leisure Suit Larry II.. 35.45 $ 

Ceny te warto porównać z cenami 
sprzętu. To daje najlepsze wyobrażenie o 
rzeczywistej wartości programu Zwykły 
14-calowy monitor kosztuje 60 $, koloro¬ 
wy 270 $, karta VGA do mego 329 $ 
Komputer kompatybilny z IBM XT firmy 
VENDEX TECHNOLOGIES w podstawo¬ 
wej konfiguracji bez twardego dysku — 
699$ 

Z tego zestawienia wymka, ze gdyby w 
Polsce ktoś chciał nabyć autoryzowany 
program, musiałby mieć bardzo dużo pie¬ 
niędzy Tańsze jest zwrócenie się do spół¬ 
ki z o.o sprzedającej software po cenach, 
które np państwowy użytkownik jest w 
stan e zaakceptować 

W tym miejscu niewielka dygresja 

Kilka lat temu doskonale „szły" w na¬ 
szym kraju programy zastępujące pracę 
księgowości w przedsiębiorstwach Doko 
nywano zakupów sprzętu, organizowano 
kursy, „wdrażano” .. i po pewnym czasie 
okazywało się, ze programy te są znako 
mite dla angielskich, amerykańskich czy 
zachodnioniemieckich przedsiębiorstw 
One były napisane nie DLA NAS 

Trzeba było przeprosić się z zarękawka¬ 
mi i ponownie przekwalifikować panie Ba¬ 
sie i Zosie 

W Stanach Zjednoczonych i Europie Za¬ 
chodniej firma softwarowa zapewnia jed¬ 
nocześnie 24-godz nny serwis. O każdej 
porze dnia i nocy użytkownik może skon¬ 
taktować się telefonicznie z ludźmi, którzy 
doradzą mu, co ma robić, kiedy program 
me chce dz ałać. W przypadku korzystania 
z pirackich kopii me jest to możliwe Czę ^ 
sto podczas „łamania program ulega y 
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uszkodzeniu, co nie pozwala na pełne wy¬ 
korzystanie jego możliwości. 

Piraci oczywiście me informują o tym 

swoich klientów 

Zupełnie inna sytuacja panuje na rynku 
gier komputerowych Tu nie są potrzebne 
specjalne programy kopiujące (mimo to 
warto je m eć'), wystarczy dwukasetowy 
magnetofon 

Wtajemniczeni twierdzą, że zdolny na¬ 
stolatek dysponujący prostym zestawem 
„ magnetofon + komputer —- jest w stanie 
zarobić w ciągu miesiąca około 150 tysię¬ 
cy złotych 

Dawno juz pojawiło się u nich przekona¬ 
nie, że program jest „niczyj' a zaraoia na 
mm ten, kto potrafi błyskawicznie zorgani¬ 
zować „produkcję” i sprzedaż 
Profesor Władysław M Turski w ten spo¬ 
sób skomentował to co dzieje się na gieł¬ 
dach Nie ma się czemu dziwie Ci mło¬ 
dzieńcy me opanowali w szkole prostej za 
sady — nie kradnij dodał tez „ Wydaje 
mi się, ze w przyszłości będziemy mieli 
kłopoty" 

W obronie istniejącego stanu rzeczy 
często przytaczany jest argument odwołu¬ 
jący się do kosztów, jakie musielibyśmy 
ponieść z chwilą wprowadzenia w Polsce 
ochrony prawnej oprogramowania — trze¬ 
ba byłoby uiścić opłaty licencyjne na rzecz 
producentów zachodnich 

Jeśli tak się stanie, to z pewnością sytu¬ 
acja zmusi wielu do racjonalnego gospo¬ 
darowania funduszami na zakupy Być 

może okaże ssę ze to samo można wy¬ 
produkować w kraju taniej! 

Uwagi te dotyczą mikrokomputerów 
Duże komputery, to zupełnie inne proble¬ 
my Po pierwsze w Polsce prawie ich me 
ma Po drugie ich oprogramowanie przy¬ 
gotowywane jest „na zamówienie ’, naj¬ 
częściej w kilku tylko egzemplarzach W 
związku z tym łatwo je chrome Po trzecie 
zastosowanie oprogramowania dodatkowo 
eliminuje potencjalnych piratów Kogo bę¬ 
dzie meresował program obsługi pasaże¬ 
rów nowego portu lotniczego na Okęciu. 

Jeśli oczywiście taki port powstanie 

W dziedzinie oprogramowania dużych 
komputerów dawno juz utraciliśmy kontakt 
ze światową czołówką 

Jeśli w tej chwili myślimy o tym, w jaki 
sposob zmniejszyć dzielący nas dystans 
powinniśmy zacząc zachowywać się jak 
ludzie cywilizowani 

Polska uczestniczy w pracach Świato¬ 
wej Organizacji Własności Intelektualnej, a 
mimo to nasze prawo autorskie i wynalaz¬ 
cze jest w niedostatecznym stopniu przy¬ 
stosowane do ochrony programów kom¬ 
puterowych przed pirackim kopiowaniem 

Jak dotychczas me było w naszym kraju 
am jednego procesu o naruszenie praw 
autorskich w tej dziedzinie- 

O ile fakt ten mst uzasadniony aktual¬ 
nym stanem prawa, to dziwi brak reakcji 
na handel tłumaczeniami instrukcji i pod 


ręczników wydawanymi w swoistym „dru¬ 
gim obiegu ” 

Prawo autorskie jednoznacznie wypo¬ 
wiada się na temat publikacji „bez wiedzy i 
zgody autora" Tymczasem bez najmniej¬ 
szych problemów można kupie opisy g f er, 
instrukcje obsługi, podręczniki programo¬ 
wania, tp. Słone ceny me zniechęcają na¬ 
bywców Mimo wysiłków krajowych auto¬ 
rów i wydawców brak jest literatury infor¬ 
matycznej, szczególnie tej na poziomie 
podstawowym, przeznaczonej dia maso¬ 
wego użytkownika 

Stan ten powinien jaK najszybciej ulec 
zmianie. 

CO NAS CZEKA ? 

Z pewnością doczekamy się zmian w 
prawie autorskim które uwzględnią intere¬ 
sy programistów Nie zmieni to od razu 
starych nawyków, nie znikną z dnia na 
dzień ludzie handlujący kradzionymi pro¬ 
gramami. Będzie jednak podstawa prawna 
do walki z nimi. A co najważniejsze — 
może wreszcie doczekamy się rodzimego 
przemysłu softwarowego. Ta produkcja 
bardzo się opłaca. 

Istniejące obecnie firmy, które sprzeda¬ 
ją własne programy, me będą musiały sto¬ 
sować drogich zabezpieczeń hardwaro- 
wych Byc może stanie się opłacalna pro¬ 
dukcja oprogramowania dostępnego dla 
przeciętnego odbiorcy 

Mam nadzieję, że przy okazji zmienią 
się tez nasze niedobre nawyki. 

Koszty zwłoki ponosany wszyscy. Je¬ 
stem przekonany, że prędzej czy później 
zachodnie firmy zareagują na bezprawne z 
ich punktu widzenia praktyki Polakow To, 
że dotychczas me znam przykładu takiej 
drastycznej reakcji świadczy ze me je¬ 
steśmy dla nich liczącym się partnerem 

Obraz ten byłby niepełny bez informacji 
o tym, co mimo trudnych warunków pro 
buje się robić. 

Podczas targów „ infosystem 89 spół¬ 
ka „Aplicom” przedstawiła autoryzowaną 
wersję programu AutoCad wraz z zabez¬ 
pieczeniem sprzętowym. Podobnie postę 
puje spółka „CyfroneK" oferująca profes¬ 
jonalny program składu gazetowego Inni 
zabezpieczają się jak mogą licząc na to, że 
uda się choć na jakiś czas odstraszyć pira¬ 
tów 

15 grudnia 1988 r Polskie Towarzystwo 
Informatyczne przedstawiło swoje stano 
wisko w sprawie ochrony prawnej progra¬ 
mów komputerowych Trwają tez w Sej 
mie prace nad nowelizacją prawa autors¬ 
kiego Mam nadzieję że jeszcze w tym 
roku zostaną uchwalone konieczne popra¬ 
wki. Wtedy może zniknie czarna flaga 
znad polskich komputerów 

Marek Czarkowski 


PROPOZYCJA DEFINICJI PODSTAWOWYCH 
ELEMENTÓW PRAWA WŁASNOŚCI PROGRAMU 


1 Przedmiotem prawa własności programu 
jest każdy program komputerowy ustalony w 
postaci 

a) kodu programowego w wersji do bezpoś¬ 
redniego wykonania przez komputer 

b) tekstu programu w języku symbolicznym 
lub innej postaci umożliwiającej automatyczne 
wygenerowanie kodu programu w wersji do 
bezpośredniego wykonania przez komputer 

1 1 Przedmiotem prawa własności programu 
jest również każdy szczegółowy opis progra¬ 
mu, tj taki op s który umężliwia proste od 
tworzenie którejkolwiek postaci z wymienio¬ 
nych w p 1 

2. Przedmiotem prawa własności programu 
jest osoba, która poniosła nakłady na opraco 
wantę programu W szczególności, jeżeli pro¬ 
gram opracowany został w wykonaniu umowy 
o pracę lub umowy o dzieło prawo własności 
programu służy pracodawcy lub zamawiające¬ 
mu 

2.1 Jeżeli kilka osob poniosło nakłady zwią 
zane z opracowaniem programu, dla określe¬ 
nia prawa każdej z osób stosuje się odpowie¬ 
dnie przepisy prawa cywilnego dotyczące 
współwłasności 

2.2 Domniemywa się, ze prawo własności 
programu służy osobie, której nazwa uwido 
czmona jest w szczegółowym opisie progra 
mu lub która uwidoczniona zostaje w zew 
nętrznych przejawach działania programu (np 
na ekranie, wydruku lub rysunku) 

2.3 Bezpośrednim twórcom programu służy 
prawo ochrony dóbr osobistych zgodnie z za¬ 
sadami prawa cywilnego Nie obejmuje ono 
jednak prawa do decydowania o sposobie wy¬ 
korzystania programu przez właściciela prawa 
do tego programu. 

3. Prawo własności programu obejmuje pra 
wo do. 

a) wyłącznego rozporządzania programem 

b) pobierania przychodów z tytułu eksploata 
cji programu 


3 1 Prawo własności programu może być w 
całości lub części zbyte innej osobie 

4 Poszczególne uprawnienia w zakresie pra¬ 
wa własności programu mogą być udzielone 
przez właściciela prawa do programu innej oso 
bie w drodze umowy licencyjnej. 

5. Korzystanie z cudzego programu może 
odbywać się wyłącznie na podstawie umowy 
zawartej z właścicielem prawa do tego progra¬ 
mu lub osobą uprawnioną wg zasad określo¬ 
nych w p 4 

6 Naruszeniami prawa własności programu 
są ponadto 

a) kopiowanie programu 

b) odtwarzanie tekstu programu w języku 
symbolicznym lub opisu programu na podsta¬ 
wie kodu programu w wersji do bezpośred 
mego wykonania. 

c) wykorzystanie istotnych rozwiązań zawar¬ 
tych w programie w opracowaniu innego pro¬ 
gramu, bez pisemnej zgody właściciela prawa 
do tego programu tub osoby uprawnionej wg 
zasad określonych w p 4 

7 Opublikowanie przez właściciela prawa do 
programu szczegółowego opisu w książce lub 
czasopiśmie uważane jest za wyrażenie zgo¬ 
dy na swobodne wykorzystywanie programu 
oraz zawartych w nim rozwiązań 

8 Usuwanie nazw osoby lub osób, którym 
przysługuje prawo własności programu oraz 
stwarzanie w lakikolwiek sposob przekonania, 
że prawo to przysługuje innej osobie lub oso¬ 
bom są ściągane Karmę. 

9 Właściciel prawa do programu lub osoba 
uoowazniona wg zasad określonych w p. 4 
może żądać od każdego Kto narusza zasady j 
określone w p 5 i 6 zaniechania tych naruszeń ; 
oraz wydania korzyści materialnych. 


Opracował Jacek Irhk 
Polskie Towarzystwo Informatyczne 
Wars za wa 15 XII1988 r 







Tak można podsumować najkrócej 
wystawę „Infosystem 89” w intencji 
organizatorów miał to byc polski CeBIT. 
Tymczasem sądząc przynajmniej po 
ilości i poziomie ofert zagranicznych 
intencji tej nie zrozumiano na Zachód 
od Łaby. Poza tak znanymi u nas już 
firmami jak ABC Data, Sofl-Tronik, czy 
Polsin niewielu odwiedziło nas gości 
Tymczasem, chociażby ze względu na 
dostępność dewiz na przetargach 
walutowych ci, którzy chcieli nabyć 
sam sprzęt woleli przeznaczyć na to 
dewizy Stąd tak wielki ruch panował 
chociażby na stoisku wspomnianego 
„Soft-Tronika”, czy debiutującej na 
naszym rynku holenderskiej firmy 
„Grocom”. 

Znacznie lepiej od wystawców 
zagranicznych zaprezentowali ssę 
rodzimi. Coraz więcej było 
kompleksowych systemów, coraz lepiej 
prezentował się rodzimy software, 
powstały często w wyniku kooperacji z 
partnerami zagranicznymi. Przykładem 
może tu byc polska wersja „Auto-CAD- 
a” proponowana przez „Aphkom” i 
licencjonowana przez brytyjski „Auto- 
Desk”, czy też „Cyfroset”, w pełni 
profesjonalny system służący do 
składu i łamania czasopism i książek. 
Ten z kolei powstał niejako „na 
zamówienie” angielskiej firmy 
„Monotype”, jednego z 
najpoważniejszych dostawców 
fotonaswietlarek na rynek polski. 
Wszystko wskazuje zresztą na to, że 
wkrótce już zarowno „Bajtek”, jak i 
„Sztandar Młodych” będą korzystać z 
tego programu. 

Dla młodych ludzi odwiedzających 
wystawę, a także dla wybranych klas 
kilku szkół poznańskich Fundacja 
Edukacji Komputerowej przygotowała 
atrakcję w postaci pracowni 
komputerowych urządzonych przez 
zajmujące stę wprowadzaniem 
informatyki do oświaty instytucje z 
kilku krajów, m in. z Bułgarii i Wielkiej 
Brytanii. Tym, którzy wciąż jeszcze 
mogą tylko marzyć o nauce w takich 
klasach i którzy nie mieli okazji 
zobaczyć „Infosystemu” dedykujemy 
ten fotoreportaż autorstwa Leopolda 
Dzikowskiego. 



KARTY TELEFAXU DO IBM PC 

Telefaxy jako urządzenia znacznie wygodniejsze od popularnych te¬ 
leksów są coraz częściej używane na swiecie Podstawową ich zaletą 
jest transmisja informacji w tryb>e graficznym, co pozwala przesyłać ry 
sunki fotografie lub tekst w alfabetach arabskim, chińskim albo jeszcze 
bardziej egzotycznym. Telefaxy są urządzeniami dość drogimi, najczę¬ 
ściej kosztują powyżej 1000 dolarow Bardzo ciekawą ofertę stanowią 
więc znacznie tańsze karty rozszerzające do komputerów klasy IBM PC 
Na rynku brytyjskim za 300 funtów oferowana jest karta Commumcate 
C~FAX SR Pozwala ona na pracę z szybkością 9600 bodow Dostarczo¬ 
ne oprogramowanie pozwala na wysyłanie tekstów tylko w formacie AS 
CU. Brak urządzenia wejściowego do wprowadzania rysunków (scanner) 
utrudnia pełne wykorzystanie tego bardzo użytecznego urządzenia. Kon¬ 
kurencyjną kartę ale z lepszym oprogramowaniem dostarcza firma In- 
terOuadram JT Fax tez kosztuje 300 funtów 

Z powodu istotnych ograniczeń rozwiązanie to, aczkolwiek tańsze od 
Kompletnego oddzielnego telefaxu, nie wzbudza powszechnego entuz¬ 
jazmu i traktowane jest na razie jako przejściowe 
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Spore zainteresowanie na tar¬ 
gach CeBIT 89 wzbudzał prezen¬ 
towany na stoisku firmy . Kodak" 
komputerowy system sporządza¬ 
nia dokumentów osobistych skła¬ 
dający się z kamery wideo i połą¬ 
czonego z nim komputera wypo¬ 
sażonego w kolorową drukarkę 
termiczną (prezentowaną jż w 
j „Bsitkowym Mikromagazynie") 
„Kodak zaproponował aby, 
poza własnoręcznym podpisem 
właściciela wszystkie inne ele¬ 
menty dokumentu (przepusrki, 
prawa jazdy >tp.) powstawały bez 
montażu. Dotyczy to w szczegół 
mości także kolorowego zdjęcia 
wmontowywanego przez kompu¬ 
ter natychmiast po jego zaakcepto¬ 
waniu przez fotografowanego ka¬ 
mera wideo jest znacznie hardziej 
cierpliwa niz papier fotograficzny 
może długo i z uporem „wpa¬ 
trywać się” w twarz, którą uwiecz 
ma w dokumencie, tak długo 
ov,póki jej operator i fotografowany 
| rśe uzgodnią, ze właśnie to, a nie 
i inne ujęcie udało się najlepiej. 
Wpisana do pamięci komputera 
„stopklatka“ jest następnie druko¬ 
wana or?v pomocy wideodrukarki 
razem z podawanymi z klawiatury 
danymi osobowymi, zapisanym za 
pomocą kodu paskowego nume 
rem dokumentu, a także jeśli jest 
to potrzebne, z wprowadzony m 


wcześniej znakiem graficznym za¬ 
stępującym pieczątkę. 

System Kodaka jest podobno 
bardzo bezpieczny niebezpiecze¬ 
ństwo podrobienia tak zrobionego 
dokumentu minimalne. Na dodatek 
dzięki takiemu systemowi tworzyć 
można bez większych problemów 
pełną komputerową kartotekę, w 
której zapisane będą w formie 
elektronicznej także wizerunki po¬ 
siadaczy dok meniów Przed 
komputerem me ukryje się nikt 
Nawet broda, wąsy, czy peruka nie 
mocą go zwieść, w każdej bowiem 
chwT e'ekifufiiczr,y wizerunek 
może być poprawiony przez doda 
nie takich właśnie szczegółów Nic 
dziwnego, że na CeBIT -de naj¬ 
większym wzięciem cieszyły się 
właśnie sporządzane od ręki (ok 
90 sekj na stoisku „Kodaka" takie 
dowody z małymi „poprawkami' 
— np. blond piękność z wąsami 
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Kolorowe monitory wysokiej rozdzie¬ 
lczości zapewniają dziś operatorowi 
komputera wspaniały obraz. Monitor 
jest także wystarczającym narzędziem 
wówczas, gdy chcemy efekty naszej 
pracy pokazać dwom- trzem przyjacio¬ 
łom Gorzej jednak a tak często bywa, 
gdy trzeba zorganizować dla kilkunastu 
iub kilkudziesięciu osób pokaz iub wy¬ 
kład z pomocą komputera i magnetowi¬ 
du Ekran monitora staje się wówczas 
zdecydowanie zbyt mały, szczegóły 
niewidoczne 

Lekarstwem na te kłopoty, ma być, 
według specjalistów firmy „Kodak” 
wprowadzany właśnie na rynek (pre¬ 
miera na CeBIT 89) projektor LC 500 
Od produkowanych juz projektorów wi¬ 
deo rożni się on zdecydowanie małymi 
rozmiarami (410x110x245 mm), wagą 
5,9 kg) oraz wspomnianą juz uniwersal¬ 
nością Na tylnej ściance projektora wi¬ 
dnieją wejścia sygnałowe composite- 
-video RGB-TTL i analogowe -RGBS, 
zarówno do magnetowidu jak i kompu¬ 
tera. Przełącznikiem wvb>era się tylko 
skąd ma byc w danej chwili pobierany 


wyświetlany właśnie na ekranie obraz. 

Niezwykle prosta jest obsługa tech¬ 
niczna projektora Jego najbardziej za¬ 
wodną częśc — żarówkę można wy 
mienie w ciągu kilku sekund me posłu¬ 
gując się przy tym nawet śrubokrętem 
Jakość kolorowego obrazu na ekranie 
(może mm byc także zwykła ściana) 
jest nienaganna 

LC 500 ma stać się, w intencji jego 
producentów uniwersalną pomocą nau¬ 
kową dla szkół i wyższych uczelni, 
obowiązkowym wyposażeniem specja¬ 
listów od marketingu prezentujących 
często i w rożnych miejscach wyroby 
swoich firm itp. W ulotce reklamowej 
Kodaka pisze się także o niewątpliwych 
zaletach posiadania takiego urządzenia 
w domu Rzeczywiście zalet takich jest 
wiele. Jest jednak wszakze i mała 
wada, na nasze warunki dyskredytująca 
to urządzenie jako domową zabawkę 
- cena Gdy na przełomie września i 
października LC 500 pojawi się w skle¬ 
pach RFN, kosztować ma ok. 8500 ma¬ 
rek 

(go) 
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SKLEP Nr 163 41 300 OBROWA GÓRNICZA, uh Sobieskiego 17 

teł. S22 371 m godx. W - W 


OFERUJE: 

- mikrokomputery 8~bitowe 

(Amstrad. Commodore. At ar ) 

- mikrokomputery klasy PC HT/AT 

- urządzenia peryferyjne 

C drukarki, plotery, stacje dysków ) 

- akcesoria i materiały eksploatacyjne 

( dyskietki, kable, kasety barwiące, pudelka,...) 

- sprzęt video i CTV 

- sprzęt elektroakustyczny klasy Hi-Fi 

- sprzęt estradowy 

- drobny sprzęt elektroniczny i gospodarstwa domowego 

SKLEP PROWADZI SPRZEDAŻ POZARYNKOWą 
PROWADZIMY KOMIS I SKUP w/w ARTYKUŁÓW 

W TYM ROKU o S Z TANBIEJ ! 

SERWIS 1S-MIESIECZN Y PROWADZI: 

PRZEDSIĘBIORSTWO 
POSTĘPU TECHNICZNEGO 

SPÓkKA z O.O. 

41-303 DĄBROWA GÓRNICZA 
Czerwonych Sztandarów 94 

te 1.647148 tlx.03128 98 

SB 33 
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KLAN ATARI 


DUSZKI W 



Grafika graczy i pocisków 
obsługiwana jest przez układy 
komputera, istnieje więc możli¬ 
wość wykorzystania jej w każ¬ 
dym języku. Można ją stosować 
również w Action!. 

Obsługa duszków wymaga zaprojektowania ca¬ 
łościowego systemu, który umożliwi realizację 
wszystkich możliwych funkcji Przede wszystkim 
konieczne jest zdefiniowanie kilku zmiennych 
globalnych, które uproszczą stosowanie grafiki 
graczy i pocisków Są to trzy zmienne proste oraz 
siedem tablic. 

PMMode — określa wybraną rozdzielczość; 

HitCIr — służy do kasowania rejestrów kolizji; 
PMBAdr — adres początkowy pamięci duszków; 
HPos — zawiera poziome pozycje duszków; 

VPos — zawiera pionowe pozycje duszków, 
MMask — zawiera masks bitowe do odczytu da¬ 
nych pocisków; 

PMHPos — ustala poziome pozycje duszków; 
PMS ze -— ustaia szerokość duszków; 

PMField — określa wielkość pamięci dla każdego 
duszka; 

PMEmpty — określa wielkość wolnej pamięci po¬ 
wyżej PMBAdr 

Elementy tablic, które mają wymiar osiem, do¬ 
tyczą poszczególnych duszków Tablica MMask 
ma cztery elementy, gdyż dotyczy tylko pocis¬ 
ków Cztery elementy tablicy PMSize określają 
szerokość graczy, a piąty szerokość wszystkich 
pocisków Tablice trzyelementowe służą do okre¬ 
ślania parametrów w zależności od wybranej roz¬ 
dzielczości. 

WŁĄCZANIE I WYŁĄCZANIE 


Przygotowanie do pracy systemu duszków wy¬ 
maga zarezerwowania odpowiedniego obszaru w 
pamięci komputera oraz wyzerowania wszystkich 
rejestrów które z mm współpracują Następnie — 
w zależności od wybranej rozdzielczości — usta¬ 
lany jest adres początkowy pamięci duszków 
(PMBAdr) i jego starszy bajt (PMBase). Dla P/MG 
jest zawsze wyznaczany obszar pamięci leżący 
poniżej pamięci obrazu. Dla zabezpieczenia tego 
obszaru zmemana jest wartość szczytu pamięci 
(MemHi) Zapamiętanie poprzedniej wartości w 
zmiennej OldMHi umożliwia późniejsze przywró¬ 
cenie stanu pierwotnego. 

Wszystkie te czynności wykonuje procedura 
PMGraphics, której parametrem jest żądana roz¬ 
dzielczość Wartość dwa odpowiada tu rozdziel¬ 
czości dwulimowej, wartość jeden — jednolimo- 
wej zas zero powoduje wyłączenie duszków 
Każda inna wartość parametru jest zmieniana na 
zero w początkowej fazie procedury dzięki cze¬ 
mu unika się błędnych wywołań Konieczne jest 
także sprawdzenie, czy grafika P/M była wcześ¬ 
niej uruchomiona Brak takiej kontroli spowodo¬ 
wałby zajęcie całej pamięci operacyjnej juz po kil¬ 
ku zmianach rozdzielczości Warto zauważyć, ze 
poprzez użycie tablicy PMEmpty zmniejsza się 
zajmowany przez duszki obszar pamięci do niez¬ 
będnego minimum Ponadto adres początkowy 
pamięci duszków jest porównywany z końcowym 
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adresem programu, co chroni orzed zniszcze¬ 
niem treści programu przez dane duszków 

KO -0R DUSZKA 


Do wyboru koloru duszka służy procedura 
PMColor, którą wywołuje się podobnie jak biblio¬ 
teczną procedurę SetColor, lecz zamiast numeru 
rejestru koloru trzeba podać numer gracza Kolo¬ 
ry pocisków są zawsze takie same jak kolory gra¬ 
czy o identycznych numerach. Działanie tej pro¬ 
cedury jest bardzo proste i me wymaga opisu 
Zarówno w tej procedurze, jak i we wszystkich 
pozostałych przyjęty został system oznaczeń sto¬ 
sowany w Basicu XE W systemie tym duszki 
mają numery od 0 do / Duszkami 0-3 są gracze 
o takich numerach, a duszkami 4-7 są pociski o 
numerach mniejszych o cztery, czyli również od 0 
do 3 Na przykład, parametr wskazujący gracza 1 
ma wartość 1, a wskazujący pocisk 1 ma wartość 5 

ADRES DANYCH 


Równie prosta jest funkcja PMAdr, która zwraca 
adres początkowy obszaru pamięci zajmowanego 
przez dane wskazanego gracza (parametry od 0 
do 3). Ponieważ dane wszystkich pocisków zaj¬ 
mują ten sam obszar, to dla parametrów od 4 do 7 
zwracana jest ta sama wartość Sposób oblicze¬ 
nia adresu jest oczywisty dla każdego, kto zna 
podział pamięci pomiędzy poszczególne duszki 

KASOWANIE PAMIĘCI 


Często zachodzi konieczność całkowitego ska¬ 
sowania obszaru danych konkretnego duszka 
Stosuje się to w celu usunięcia tego duszka lub 
całkowitej zmiany jego kształtu Operacja ta jest 
realizowana przez procedurę PMCIr, której para¬ 
metrem jest numer duszka. Wykonanie tej czyn¬ 
ności dla graczy jest bardzo łatwe — wystarczy 
użyć procedurę Zero Pociski natomiast sprawiają 
znacznie większy kłopot, gdyż każdy z nich zaj¬ 
muje tylko dwa bity każdego bajtu danych Zmu¬ 
sza to do skorzystania z pętli FOR oraz tablicy 
masek MMask W obu przypadkach adres kaso¬ 
wanego bloku określany jest przy pomocy funkcji 
PMAdr. 

POZYCJA DUSZKA 


Ruch dowolnego duszka można zrealizować 

wywołując procedurę PMMove Jej parametrami 
są kolejno- numer duszka, współrzędna pozioma 
i współrzędna pionowa, Na początku podana 

współrzędna pionowa jest porównywana z jej ak¬ 
tualną wartością. Jeśli duszek przesuwany jest w 
poziomie (dy^O), to wystarczy wpisanie nowej 
współrzędnej x do tablic EłPos i PMHPos W prze¬ 
ciwnym przypadku trzeba dokonać przeniesienia 
danych ciuszka o liczbę bajtów wskazaną przez 
zmienną dy W tym celu cały blok pamięci jest 
najpierw przepisywany do pomocniczej tablicy 
temp, a dopiero potem na właściwe miejsce 



Takie postępowanie jest konieczne dla zapew¬ 
nienia poprawnego ruchu w dół i w gorę Nieste¬ 
ty, wymaga to przepisania pot lub ćwierć kilobajta 
(zależnie od rozdzielczości) i jest stosunkowo po¬ 
wolne (jak na Action!). Na szczęście Action! 
umożliwia bardzo proste włączenie do programu 
procedur w języku maszynowym Pierwszą pętlę 
POR można zastąpić taką procedurą 


LDY 

#0 

LDA 

pptr 

STA 

$ AO 

LDA 

pptr * 1 

STA 

$ A1 

LOOP LDA 

($AO), 

AND 

mask 1 

STA 

temp ,t 

INY 


CPY 

p 1 i en 

BNE 

LOOP 


listing 1 


Zmieniając to na kod liczbowy otrzymamy tablicę, 
którą należy umieścić w procedurze PMMove we 
wskazanym miejscu (zamiast pętli) 

i $AQ O $AD pptr $65 $AO $AD pptr+i 
$85 $A1 $B 1 $AO $2D maski $99 temp 
$C8 $CC pllen $DQ $F2 ] 

listing 2 

Podobna procedura posłuży do przepisania za¬ 
wartości tablicy temp do odpowiedniego obszaru 
pamięci duszków Jest ona nieco dłuższa, gdyż 
trzeba pilnować, aby me został naruszony biok 
danych następnego duszka 



LDX 

#0 


LDY 

offy 


LDA 

pptr 


STA 

*A0 


LDA 

pptr + 1 


STA 

$Ai 

LOOP 

LDA 

($ AO ), Y 


AND 

mask2 


ORA 

STA 

temp,X 

( $ AO ) , Y t1g3 


INY 



CPY 

p 1 i en 


BNE 

SKIP 


LDY 

#0 

SKIP 

INX 



CPX 

p 1 i en 


BNE 

LOOP 

Po zamianie 

na liczby otrzymujemy drugą tablicę 


Zastępujemy mą drugą pętlę FOR 

t $A2 O $AC offy $AD pptr $0B $AG $AD 
pptr ♦ i $85 $ A i $B1 $ AO $2D tnask2 
$1D temp $91 $AO $C8 $CC pllen $DO 2 
$ AO O $E8 $EC pllen $DO $E6 1 

listing 4 

W tym przykładzie doskonale widoczna jest 
elastyczność systemu Action! Użytkownik me 
musi znać miejsca, w którym zostaną umieszczo 
ne procedury i wykorzystywane przez nie dane. 



KLAN ATARI 


Wpisane do tablicy zmienne określające adresy 
zmiennycn zostaną orzez Actson? zamienione na 
odpowiednie wartości w procesie kompilacji pro¬ 
gramu 

TWORZENIE DUSZKA 


Majac juz procedury niezbędne do operowania 
duszkami na ekranie możemy przystąpić do 
stworzenia ich. Będzie to polegało na umieszcze¬ 
niu zestawu danych w odpowiednim miejscu pa¬ 
mięci oraz ustaleniu wybranej szerokości i pozycji 
na ekranie W tym celu należy wywołać procedu¬ 
rę PMCreate, a jako jej parametry podać kolejno: 
numer duszka, tablicę zawierającą dane duszka, 
liczbę elementów tej tablicy, szerokość duszka i 
współrzędne ooczątkowej pozycji. Procedura 
przepisuje tylko podane dane na właściwe miejs¬ 
ce oraz wpisuje pozostałe parametry do odpowie¬ 
dnich rejestrów i tablic. Jeśli we wskazanym ob¬ 
szarze znajduje się już inny wzór duszka, to zo¬ 
stanie on usunięty tylko w tych miejscach, gdzie 
pokrywa się z nowym wzorem. 

KOLIZJA 


Do pełnego szczęścia brakuje już tylko wykry 
wame kolizji duszków z innymi duszkami i ele¬ 
mentami planszy Wykorzystamy tu funkcję 
PMHit, która zwraca wartość i w przypadku wy¬ 
stąpienia wskazanej kolizji, a zero, gdy takiej koli¬ 
zji me było Parametrami funkcji są dwa numery 
Pierwszy z nich wskazuje duszka, którego kolizję 
badamy Drugi parametr jest numerem obiektu, z 
którym badany duszek mógł się zderzyć Wartość 
tego numeru z zakresu od 0 do 3 odpowiada nu¬ 
merowi gracza, zaś wartość od 4 do 7 jest zwięk¬ 
szonym o cztery numerem rejestru koloru, który 
był wykorzystany do narysowania elementu plan¬ 
szy. Jest to więc numer użyty w procedurze Set- 
Color zw ększony o cztery 

unkcja PMHit me kasuje zawartości rejestrów 
kolizji, co umożliwia kolejne sprawdzanie kilku 
zderzeń Po wykonaniu wszystkich niezbędnych 
wywołań tej funkcji trzeba skasować te rejestry, 
aby zapewnie poprawne wykrywanie dalszych ko¬ 
lizji W tym celu wystarczy przypisać zmiennej 
HitCIr dowolną wartość UWAGA wszystkie reje¬ 
stry kolizji są kasowane jednocześnie 

ZMIANA GRAPHICS 


Zmiana trybu graficznego obrazu przy aktyw¬ 
nych duszkach może spowodować częściowe 
nałożenie się wykorzystywanych obszarów pa¬ 
ni ęci. Aby tego umknąć trzeba przed każdą pro¬ 
cedurą Graphics wyłączyć duszki Czynność tę 
także przerzucimy na barki komputera Wykorzy¬ 
stamy tu sposob działania Aciion!, który powo¬ 
duje, ze każda nowa definicja procedury lub 
zmiennej powoduje anulowanie poprzedniej o tej 
samej nazwie Dotyczy to rowmez procedur bi¬ 
bliotecznych Napiszemy w ęc, po prostu, nową 
procedurę Graphics, która zastąpi procedurę bi¬ 
blioteczną 

STOSOWANIE 

Na zakończenie wypada wyjaśnić, jak korzy¬ 
stać z opisanego zestawu procedur Należy 
umieścić go na początku pisanego programu, a 
po nim wpisać słowo MODULE i resztę własnego 
programu Teraz można juz swobodnie korzystać 
ze wszystkich pokazanych procedur 

W celu uzyskania duszków należy w dalszej 
części programu wykonać kilka prostych czynno¬ 
ści: 

— ustalić odpowiedni tryb graficzny (Graphics), 

— wybrać rozdzielczość duszków (PMGraphics); 

wyczyscic odpowiedni obszar pamięci 
(PMCIr); 

— utworzyć wybrane duszki (PMCreate). 

Następnie można dowolnie przesuwać utwo¬ 
rzone duszki przy pomocy PMMove, badać ich 
zderzenia przez PMHit, usuwać je przy użyciu 
PMCIr oraz ponownie tworzyć wywołując PMCre¬ 
ate. Możliwa jest również zmiana rozdzielczości, 
lecz niszczy to wszystkie istniejące duszki. G r afi- 
ka graczy i pocisków jest aktywna, az do zmiany 
trybu graficznego lub wywołania procedury 
PMGraphtcs(O) 

Wojciech Zientara 


i Duszki w Actioni 
t Wojciech Zientara 
; Copyright (c) Bajtek 


{Umieszczenie duszka na poz>eji x,y 
PROC PMMove(BYTE n,x,y>; 


BYTE PMMode*[03,HitCIr= $D01E 
CARD FHBAdr 

BYTE ARRAY 

HPos{ 8 )®{O 000000 03, 

VPos( 8 ) = [ O 0 0 0 0 0 0 03, 

MMask(4 ) = C$FC $F3 $CF $3F3, 
PMHPos (8 ) =$DGOO, PMS i ze (5 ) =*0008 

CARD ARRAY 

PMFie 1 d»[O 2 S© 1283, 

PMErapty*[O 768 3843 

; W 1aczanie/wy iaczanie duszków 

PROC PMGraphics< BYTE modę) 

BYTE DMĄC t 1 = $22F, GTIACU=$26F, 
PMBase=$DA07,PMGraf*$DOOD 

CARD MemHi= $2E5,O idHHi»AppMHi~$E 

CARD ARRAY PMHask^tO $F800 $FC003, 
PMMem*tO *800 *4003 

IF modę > 2 THEN 
modę = O 

Fi 

Zer o (PMHPos 5 , 8 ) 

Zero<HPos» 8 ) 

Zero(VPos # 8 ) 

Zero(PMS1 ze,5) 

Zero(PMGraf,5) 

IF PHMode#0 THEN 
MemHi=01dMHi 
DMACt1= $22 GTiACt1=0 
FI 

IF mode~0 THEN 

DMACt\=$22 GT1ACt1=0 
ELSE 

iF modeli THEN 
DMACti -$ 8 E 
ELSE 

DMACt1=$2E 
FI 

O 1dMHi=MemHi 

PMBAdr=(HemHi-PMMem(modę)-$80) & 

PMMas k(modę) 

PMBase-PMBAdr RSH 8 
IF PMBAdr<AppMHi THEN 
DMACtI -$22 GT1ACti=0 
RETURN 

Fi 

MemH i *PMbAdr + PHEsnpty (modę ) 

GTI ACt 1 

FI 

PMMode-mdde 

RETURN 

> Ustalenie koloru duszka 
PROC PMCo1or(BYTE n,hue,lum) 

BYTE ARRAY Co 1 PM(4)-$2C0 


n = = &3 

ColPM(n)=(hue LSH 4) % (lum & $0F> 
RETURN 

;Adres danych duszka 

CARD PUNC PMAdr(BYTE n) 
n = =&7 

IF n> = 4 THEN 
n = Q 
ELSE 
n =* - + i 
F I 

RETURN(PMBAdr + PMEmpty(PMMode) + (n# 

PMFie1d(PMMode))) 


CARD i 

BYTE o tfy »pł 1 en,mask 1 ,mask2 
INT dy 

BYTE ARRAY temp(256),pptr 

IF PMMode^O THEN RETURN FI 
n = = &7 


dy = y-VPos(n) 

IF dy=0 THEN 

PMHPos(n) 3 x HPos(n)= x RETURN 

FI 


ppt r =PMAdr(n) 

pl1en-PMFie1d(PMMode) 

IF dy> ~0 THEN 

of f y = dy 

ELSE 

of fy ~p 1 Ien + dy 
FI 

IF n<4 THEN 

maskl~255 raask2 = Q 
ELSE 

mask2*MMask(n&3) maski-roask2!$FF 
FI 

FOR i=0 to pilen-1 ; tu pierwsza 

DO ; procedura 

temp(1)=pptr(i)&mask1 ; w jeżyku 

OD ; maszynowym 

FOR i=0 to plien-1 ; tu druga 

DO i 


pptr( o i f y )= =&mask2 % 
of f y~~ + 1 

IF offy>=pilen THEN 

of fy~0 

FI 

OD 


temp(1) 

; procedura 
; w jeżyku 
; maszynowym 


VPos(n)=y PMHPos(n)=x HPos(n)=x 
RETURN 

; Uruchomienie duszków 


PROC PMCreate(BYTE n BYTE ARRAY pra 
BYTE 1 en,si ze,x,y) 


BYTE 1,raask,trap»tetnp,oldsize=£03 
BYTE ARRAY pptr,msize=CO 1 O 33 


n = 7 

IF n<4 THEN 
mas k=0 
ELSE 

temp»n&3 mask=MMask(temp) 

FI 

pptr*PMAdr(n) 

FOR 1=0 to len-i 
DO 

pptr(i+ y)*=&raaskftpm(1> 

OD 

si ze = = -1 
IF n<4 THEN 

PMS i ze (n)-*size 
ELSE 

tBip*(asize(size) LSH (temp LSH 1)) 
oldsize**& mask % trop 
PMSize(4) s oidslze 

FI 

PMHPos(n)=x HPos(n)*x VPos(n)=y 
RETURN 


; Kolizje duszków 

BYTE FUNC PMHit(BYTE n,cn) 

BYTE ARRAY pmpf(8)=$D000»pmpm(8)**D008 


; Kasowanie obszaru pamięci duszka 

PROC PMCIr(BYTE n) 

* 

CARD ctr 

BYTE ARRAY PlAdr 
n — k? 

PlAdr =PMAdr(n) 

IF n^4 THEN 

Zero(PlAar,PMFi e ld(PMMode)) 
ELSE 
n - ~ - 4 

FOR ctr=0 TO PMF ie1d ( PMMode)-1 
DO 

P1Adr(ctr)==&MHask(n) 

OD 

FI 

RETURN _ - . „ , - - 


n ~& 7 

IF n<4 THEN 
n ss + 4 
ELSE 
n» = “4 
FI 

IF en<4 THEN 

RETURN ( (ptapirt(n) RSH cn) & 1) 

ELSE 

cn s *S(3 

RETURN ((pmpf(n) RSH cn) & 1) 

F! 

RETURN (O) 

; Nowa procedura Graphics 

PROC Graphics(BYTE modę) 

€lose(6) PMGraphics(O) 

0pen<6,"S t M ,(modę Ł $F0) i fiC,mode) 
RETURN 
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BEZ TAJEMNIC 


‘ 
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Śk .A &k- 



Wśród ogromnej rzeszy 
Miytkownikow Atari 800XL 
6§XEzbaidu}e się spora 
grupa osób, które chętnie 
' poznałyby system operacyjny 
komputera. Zgłębienie Jego 
. tajemnic dostarczy wiele 4 
satysfakcji wśzysfkim tym 5 
którzy riifc boją śię zrńagan z 
> trudnymi problemami. 
Zdobyte tą ptogą informacje, 
przydadzą $ję me tylkojakCr 


unkcjonu korhputer i 
optymaklie wykorzystać lego 

zalety. 

Po kilku taldch stówach 
zaęhęty w niejednej głowie 
źr dźi się pytanie, jak zabrać 
się do z am apia systemu 
operacyjnego. Zadanie to nie 
fest takie proste, naWet jeśil 
dysponujemy odpowiępnimł 
pakietami oprogramowania, 

V Wymaga to wiefu godziff 
pracy i żmudnych analiz, 
znacznie łatwiej jest 
skorzystać z gotowych J 
pomocy.J 

Pierwszą w Polsce i jedną ? 
rfłeliczbyth W s wiecie książek, 
W których znajdziemy bardzo 
szczegółowyopis systemu 
operacyjnego, jest 
czteroćzęścfowa „Mapa 
pamięci Atarj XL/X ” napisana 1 
przez Wójciecha Zientarę, 
Pierwąza część, ,Podstawowe 
procedury systemu 
operacyjnego”, to klucz do : 
poznaniacałegozagadnienia. 1 
Opisano tu, co 4zieje się w 
komputerze po Włączeniu 
zas iania, jak rozpoznajeop 
dołączór urządzenia 
* zewnętrzne i w jaki sposób 
czytane sąLinformacje 
zapisane na mAfnetofonie, 
stacji dysków. Kolejny blok 
procedur to procedury 
przerwań. Są one jedną, 
najmoenWszych shoi,, 
systemu operacyjnego Atarił 
dlatego programiśó batdżOfe 
chętnie posługują ste nimi ' 
przy pisaniu programów, w 
dalszej częśpi książki opisanę 

procedury 
zmiennoprzecinkowe, które 
znajdują zastosowanie we 
wszelkiego rodzaju 
obliczeniach. 
Dfa wygody czytelników 
•utor opracował szereg 
dodatków ułatwiających 
korzystnie z lążkL Znajduje 
się wśród nich zestawienie 
adręsow wszystkich procedur 
systemu operacyjnegó, tabela 
z adresami rejestrów^ zmienne 
systemowe f słowniczek 
terminów informatycznych, 
J* « Książk^boieciłpym 

szczególnie iy m, którzy 
poważnie myśia f o pisaniu 
programów na Atari XL/XE. 
Będzie ona dla nićh jedna z 
podstawowych pomocy. 


Wojciech Zientara, ,^Aapa 
pamięci Atari XL/XE — 
Podstawowe procedury 
systemu operacyjnego”* 
Stołeczny Ośrodek Etek* 
Ironicznej Techniki OWł* 
cieniowej, Warszawa 
1988, Wyd. I, Nakład 5000 
egz. 
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DLA KAŻDEGO- 

Z pewnością każdy zna śmieszną 
figurkę Rockforda z gry „Boulder 
Dash”. Wpadłem na pomysł, aby 
wykorzystać ją do uatrakcyjnienia 

programów edukacyjnych dla dzie¬ 
ci. 


Program' ecbka ryjne pisane w GRAPHICS 0 są 
uzupełniane postacią Rockforda, który jest dla 
dzieci uronieniem komputera Gdy dzieci odpo¬ 
wiadają, 1 iii je za poprawną oćpow edź lub gani 
za złą 

Pokazany podprogram należy dołączyć do włas¬ 
nego programu. Jeno użycie jesr bardzo proste. 
Procedura GOSUB 870 powoduje ukazanie się 
Rockforda na pozycji określonej zmiennymi X i Y 
Potem można wykonać dowolną sekwencję proce¬ 
dur tak, jak jest to pokazane w wierszu 1080 W 
międzyczasie na ekranie może się pojawiać tekst, 
dzieci mor odpowiadać na pytania itp Usunięcie 
postaci F kforda wykonuje procedura GOSUB 
890 

Zdenek Ruty 


SD 10 REM s POCKFORD 
FM 20 REM : Zdenek Ruby 

DA 30 REM Copyright (C) Ba * tek 
BB 40 REM 

IR 100 GRAPHICS O.-POKE 71Q,0;P0KE 712 # 0:P 
OKE "^2, l 

QG 105 SIT I ON 2,7:? »---- 


GY 110 POSITION 5,10:? "Obraz zgaśnie ter 
az na minuta" 

MU 115 msITION 2,13:? "--- 


QF 120 FOR DEL-i TO 500:NEXT DEL 
SM 125 REM DEFINIOWANIE ZNAKU ROCKFORDA 
KF 130 !=PE£K(106)~4:P0KE 106,1 
NJ 135 GRAPHICS OjPOKE 756,1:1=256*1 
00 140 l KE ?52,it; "j:FOKĘ 710,1 

IA 145 FUR J=0 TO 1023:POKE I♦ J,PEEK< 5734 
4+J):NEXT J 

J2 150 RESTORE 16O:F0R J*i TO 200:R£AD K: 


QR 
SR 
IG 
RV 
KO 
RX 
IK 
RZ 
ZO 
ZQ 
WM 
NR 
IC 
GP 
AX 
GR 
GO 
J J 
ZW 
LL 
OB 
KB 
RY 
XS 
SA 
KF 
SC 
KC 
HF 
UB 
RN 
VX 
RP 
TM 
RR 
JR 
GU 
10 
Y V 
YZ 
HP 
BO 
HR 
01 
XH 
HG 
WF 
GP 
NC 
AJ 
NX 
JV 
GV 
LB 
G> 



POK 1 

E 519 + J-M»K:NEXT J 

JE 

BC 

155 

GOTO 

1000: REM DEMONSTRACJA 

SF 

DF 

ISO 

REM 

ROCKFORD 

OH 

PT 

161 

DATA 

12,31,31,51,51,31,3,0 

AK 

XJ 

162 

DATA 

15,18,39,192,7,12,12,60 

HF 

BN 

163 

DATA 

48,248,248,204,204,248,192,0 

LJ 

GE 

164 

Dr T a 

240,72,228,3,224,48,48,60 

HH 

SM 

165 

DA^a 

12,31,31,63,51 31,3,0 

NU 

VF 

1G6 

DATA 

12,31,31,63,63,31,3,0 

IB 

EL 

167 

DATA 

48,248,248,252,204,248,192,0 

IH 

HM 

168 

DATA 

48.248,248,252,252,248,192,0 

YT 

NC 

169 

DATA 

15,18,39,192,7,12,60.0 

ZI 

Dk 

170 

DATA 

15,18,39,192,7,60,0,0 

ZT 

GH 

171 

DATA 

240,72,228,3,224,48, 60,0 

SL 

KE 

172 

DATA 

240, "*2,228, 3, 224,60,0,0 

us 

LQ 

173 

DATA 

15,18,39,24,7,12,12,60 

OJ 

EY 

174 

DATA 

15,18, n 3 t 12,7,12 s 12,60 

QF 

WK 

175 

DATA 

240,72,228,24,224,48,48,60 

QM 

XV 

176 

DATA 

240,72,232,48,224,48,48 60 

AD 

WA 

177 

DATA 

240, 12 ,, 232, 48,224,48, 60, 0 

KK 

WH 

178 

DATA 

15,18,23,12,7,12,60,0 

TU 

FN 

179 

0A1 A 

15,18,23,12,7,12,12,60 


FZ 

180 

DATA 

243,74,228,0,224,48,48,60 


RF 

181 

DATA 

255,192,228,194,201,228,210,1 

LJ 


93 



ZB 


LC 

182 

DATA 255,3,11,3,7,75,147,3 


VH 

183 

DATA 194,196,200,194,228,200,192,2 



55 


CP 

JN 

! 84 

DATA 131,67,11,71,35,23,3,255 

Q I 

I S 

185 

DATA 255,255,195,227,243,255,255,2 

DT 


55 


T3 

SE 

195 

REM Kostka 

EF 

MT 

200 

POSITION X,Y:? CHR$(25)?CHR$(25) 

FR 

DN 

205 

POSITION X,Y+1:? CHR*(25>;CHR*(25) 

YQ 

ND 

210 

REM FOR 1=1 TO 5:GOSUB 320:NFX7 I 

FC 

ZP 

215 

RETURN 

PB 

NV 

225 

REM Rczprysk 

TQ 

EY 

230 

POSITION X, Y : ? CHR$ ( 21 ) ,* CHR* ( 22) 


AE 

235 

POSITION X,Y+1:? CHR$(23);CHR3<24) 

RB 

ZG 

240 

RETURN 

IQ 

PR 

295 

REM PAUZA I 

RB 


300 FOR DEL= 1 TO 20:NEXT DEL:RETURN 
315 REM PAUZA II 

320 FOR DEL=1 TO 100:NEXT DEL:RETURN 

395 REM Postoj Rock!orda 

400 FOR 1=0 fO 1?FOL J=C TO 1 

405 POSITION X+I.Y+J:? CHR*<2*l+J+l) 

410 NEXT J:NEXT I:GOSUB 320:RETURN 

435 REM Mruganie oczami 

440 GOSUB 320 

445 POSITION X,Y:? CHR$(5);CHR$(7) 

450 GOSUB 300 

455 POSITION X,Y:? CHR$< 6 >;CHR$< 8 ) 

460 GOSUB 300 

-465 POSITION X, Y: ? CHR*<5>;CHR*(7) 

470 GOSUB 300 

475 POSITION X,Y s ? CHR*(1);CHR*(3) 

480 RETURN 

495 REM Przytupywanie 

500 FOR 1=1 TO 5 

505 POSITION X, Y * 1 : ? CHR$(9) 

510 GOSUB 300:GOSUB 300 
515 PGSniON X,Y+1:? CHR$(2> 

520 GOSUB 300;GOSUB 300 
525 NEXT I 

b30 GOSUB 320;GOSUB 320 
535 RETURN 

545 REM Maszerowanie 
550 FOR !=1 TO 5 

555 POSITION X,Y*i : ? CHR$<9);CHR$(15) 
56C GOSUB 300 

565 POSITION X» Y +1:? CHR$(10);CHR$(16> 
570 GOSUB 300 

575 POSITION X,Y+1:? CHR$(9);CHR$C15) 
580 GOSUB 300 

585 POSITION X,Y+1:? CHR*( 2 ) ; CHR*(4) 
590 GOSUB 300:GOSUB 300 
595 POSITION X, Y+ 1:? CHR$(13);CHR*(11) 
600 GOSUB 300 

605 POSITION X,Y+1:? CHR$<14>;CHR$< 12) 
610 GOSUB 300 

615 POSITION X,Y+1:? CHR$<13);CHR$<11) 
620 GOSUB 300 

625 POSITION X, Y+ 1:? CHR$(2);CHRi(4) 

630 GOSUB 300:GOSUB 300 

640 NEXT I:GOSUB 320:RETURN 

655 REM Złożenie rak, tupanie 

660 POSITION X,Y+1 ; ? CHR$(13);CHR$(15) 

665 GOSUB 300:GOSUB 300 

670 POSITION X,Y+1 : 9 CHR$(14>;CHR$(16> 
675 GOSUB 300:GOSUB 300 
680 FOR 1=1 TO 5 

685 POSITION X +1,Y +1:? CHR$(17) 

690 GOSUB 300:GOSUB 300 

695 POSITION X+i,Y+ 1 :? CHR$(16) 

700 GOSUB 300:GOSUB 300 
705 NEXT I:RETURN 

715 REM Jedna podniesiona, tupanie 

720 FOR hi TO 5 

725 POSITION X,Y+i:? CHR$(18);CHR$(4) 

730 GOSUB 300;GOSUB 300 

735 POSITION X,Y+1:? CHR*<19) 

740 GOSUB 300:GOSUB 300 
745 NEXT I:GOSUB 320:RETURN 
765 REM Machanie ręka 
770 FOR 1=1 TO 5 

775 POSITION X,Y +i:? CHR$(19>iCHR$(20> 

780 GOSUB 300:GOSUB 300 

785 POSITION X,Y+ 1 :? CHR$(19);CHR$(4) 

790 GOSUB 300:GOSUB 300 

795 NEXT I:RETURN 

805 REM Wymazanie 

810 POSITION X,Y:? CHR*(32);CHR$(32) 

815 POSITION X,Y+1:? CHR$(32);CHR$(32) 

820 RETURN 

825 REM Trzask 

830 FOR 1=15 TO 1 STEP -1 

835 SOUND 0.5,2,I:SOUND 1,60,4,1 

840 SOUND 2,10,8,I:SOUND 3,10,8,1 

845 NEXT I:FOR DEL=i TO 10:NEXT DEL 

850 FOR 1=0 TO 3;SOUND I,0.0,0:NEXT I 

855 RETURN 

865 REM Pokazanie Rockforda 
870 POSITION X,Y;GOSUB 200:GOSUB 830:G 
OSUB 230:GOSUB 830;GOSUB 400:GOSUB 830 
:RETURN 

885 REM Usuniecie Rockforda 
890 POSITION X,Y;GOSUB 230:G0SUB 830;G 
OSUB 200:GOSUB 830:G0SUB 320:G0SUB 810 
:GOSUB 830:RETURN 
995 REM DEMONSTRACJA 

1000 A=INT<RND(0>*3)i1F A=2 THEN A=-l 
1010 X=19+10*A 

1020 B=INT<RND(0>*3>:IF B = 2 THEN B = ~i 

1030 Y=ii+7*B 

1040 POSITION X-2,Y + 2 

1050 FOR K=1 TO 6 :? CHR$(160);:NEXT K 
1060 C=INT(RND<0)*6)*1 
1070 GOSUB 320:GOSUB 870:GOSUB 320 
1080 ON C GOSUB 440,500,550,660,720,77 

O 

1090 GOSUB 320:GOSUB 890:GOSUB 320 
1100 POSITION X-2,Y+2:? " w 

1110 GOSUB 320:GOTO 1000 
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OBft'AZK‘l III DATA 


Pisząc program często napo¬ 
tykamy na problem, jak w sto¬ 
sunkowo niewielkiej pamięci 
komputera zmieście kilkanaś¬ 
cie lub kilkadziesiąt rysunków. 
Zwykle w takich przypadkach 
stosuje się odczytywanie rysu¬ 
nku z dyskietki lub rysowanie 
normalnymi instrukcjami grafi¬ 
cznymi. 

Drugi z podanych sposobow jest całkiem niezłym ro¬ 
związaniem, szczególnie przy zastosowaniu Turbo Ba- 
sica, gdzie rysowanie est stosunkowo szybkie. Dla 
prostych rysunków spełnia to doskonale postawione 

zadanie Listing 1(w Turbo Basicu) pokazuje przykład 
takiego właśnie rysunku 

Wykonywany obrazek pochodzi z mojego programu 
, MPZZM Podczas pisania tego programu pojawił się 
jednak poważny kłopot Pokazaną metodą można 
umiescic w programie kilkanaście obrazków ale po¬ 
trzeba ich było kilkadziesiąt Nie da się tego zrobtc ma¬ 
jąc do dyspozycji 36 KB pamięci na cały program. Ko¬ 
nieczne jest skondensowanie rysunku. 

Istnieje kilka sposobow zagęszczania danych w pa¬ 
mięci komputera jednak żaden z nich mi me odpowia¬ 
dał. Zamiast zagęszczać obraz postanowiłem zrobić to 
z rysującymi go instrukcjami. W efekcie powstała pro¬ 
cedura GRAF i kilka procedur pomocniczych, które są 
przedstawione w listingu 2 

Jak to działa 7 W ększosć instrukcji graficznych Basi- 
ca posiada dwa parametry Można więc zakodować je 
w trzech bajtach, instrukcja i dwie współrzędne Naj¬ 
oszczędniejszym sposobem zapisu bajtu w programie 

jest przedstawienie go w postaci odpowiedniego znaku 

w kodzie ATASCII Do odczytania jego wartości można 
wtedy uzyc funkcji ASC C ąg tak zakodowanych baj¬ 
tów umieszcza się w instrukcji DATA 

Procedura GRAF odczytuje wskazany ciąg z DATA i 
kolejno dekoduje zawartą w nim informację Pierwszy 
rozpoznany znak oznacza rodzaj instrukcji, a dwa na¬ 
stępne — jej parametry. Ponieważ poszczególne ope¬ 
racje są określone kodam od 1 to kod ten wykorzysty¬ 
wany jest do wyboru odpowiedniej procedury pomoc¬ 
niczej przez instrukcję ON/GOSUB (wiersz 570). Rea¬ 
lizacja procedur przeoiega w pęti WHILE, aż do napot¬ 
kania litery Q zamiast kodu operacji Po każdym oaczy 
taniu trzech pierwszych bajtów ciągu są one usuwane 
Wartości kodów operacji ustaliłem następująco: 

1 — PLOT 

2 — DRAWTO 

3 — FILLTO 


4 -- PAINT 

5 — TEXT 

6 — CIRCLE 

7 — COLOR 

8 — SOUARE 

Wykonanie pierwszych czterech operacji przez od¬ 
powiednie procedury pomocnicze (PLT, DRW FLT i 
PNT) nie wymaga komentarza. Ponieważ zawsze od¬ 
czytywane są dwa parametry to instrukcję COLOR po¬ 
łączyłem z FCOLOR (wiersz 660) Instrukcje TEXT i 
CIRCLE wymagają jednak trzech parametrów Brakują¬ 
cy parametr jest odczytywany w procedurze pomocni¬ 
czej. Oczywiście konieczne jest po tym usunięcie 
tego znaku z ciągu, Sposob realizacji tych instrukcji 
można zobaczyć analizując procedury TXT i CRC 
(wiersze 640 650) 

Zastosowanie takiego rozwiązania pozwala na two¬ 
rzenie dodatkowych własnych instrukcji graficznych 
Przykładem jest tu procedura SQR, która rysuje pro¬ 
stokąt W ciągu należy dla mej umiescic kolejno współ¬ 
rzędne prawego, górnego oraz lewego, dolnego naro¬ 
żnika Podobnie można utworzyć procedury realizujące 
inne operacje. 

Ponieważ ciąg z zakodowanym rysunkiem jest umie¬ 
szczony w instrukcji DATA, to me może się w nim zna¬ 
leźć przecinek (kod ASCII=44). Zmusza to do omijania 
tej współrzędnej przy rysowaniu Aby wyeliminować tą 
niedogodność zastosowałem sprawdzanie wartości 
parametru w wierszach 540 i 550, Jeśli parametr prze¬ 
kracza dozwoloną wartość (dla trybu GRAPHICS 7 jest 
to 160) to należy go zmniejszyć W ten sposób zamiast 
przecinka (kod 44)irzeba zastosować znak o kodzie 
44 + 160 = 204 (litera L w negatywie). 

Teraz cały rysunek, który zajmował pięć wierszy, 

można zapisać w postaci jednej instrukcji DATA. Wy¬ 
gląd takiej instrukcji, zawierającej obrazek z pierwsze¬ 
go listingu, jest pokazany na listingu 3. Kolejne obrazki 
powinny być zapisane w wierszach numerowanych od 
10 000 co 2. Trzeba ponadto pamiętać, że każdy ciąg 
mus się konczyc literą Q 

Jak korzystać z procedury GRAF? Proszę spojrzeć 
na listing 4 Na początku trzeba zadeklarować zmienną 
$ która służy do odczytu ciągu z DATA Następnie 
ustalamy numer obrazka (wiersz 110) i ustawiamy 
wskaźnik odczytu przez READ na wiersz zawierający 
żądany obrazek (wiersz 120) Teraz pozostaje tylko 
wybranie trybu graficznego i właściwych Kolorów oraz 
wywołanie procedury GRAF Działanie całego przykła¬ 
du można obejrzeć po połączeniu w jeden program li ¬ 
stingów 2, 3 i 4 

Pokazane przykłady napisane zostały w Turbo Basi¬ 
cu Nic jednak nie stoi na przeszkodzie, aoy wykorzy¬ 
stać je w Atari Basic. Przetłumaczenie nie powinno sta¬ 
nowić problemu nawet dla początkującego próg rami 
sty Ponieważ Atari Basic jast znacznie wolniejszy, to 


dla przyspieszenia rysowania warto przed wywołaniem 
GRAF wyłączyć obraz instrukcją POKE 559 0 a po ej 

zakończeniu ponownie włączyć przez POKE 559,34 


Wojciech Zientara 


LISTING 1 


GE 497 - 

NP 498 REM * GRAFIKO * 

OK 499 - 

HM 500 PROC GRAF 

OO 510 READ 5$ 

MD 520 MHILE A5Ct5$3<>81 

TR 530 Z=fl5CC5$) 

GF 540 X=A5CtS$CX233:IF X>160 THEH X=X-16 

O 

UN 550 Y—ASCC5$CX333:IF Y>16G THEH Y=Y~16 

O 

MR 550 5$-5$C43 

RL 570 OH Z EXEC PLT,DRT,FLT,PNT,TXT,CRC, 

COL,5QR 
HK 580 MEND 

HF 590 ENDPROC 

OL 599 - 

TI 500 PROC PLT:PLOT X,Y:EHDPROC 

F 5 510 PROC DRT :DRAMTO X,Y:EHDPROC 

ZM 520 PROC FLT:FILLTO X,Y:EHDPROC 

5R 630 PROC PHTIPAIHT X,Y!EHDPROC 

HY 640 PROC TXTJZ=ASCC5$3:5$=5$CX23:TEXT 

X,Y CHRS (Z3 :EHDPROC 

RO 650 PROC CRC:Z=A5CC5$3:S$-S$CX23:CIRCL 

E X,Y,Z:EHDPROC 

RQ 660 PROC COL:COLOR X;FCOLOR Y:EHDPROC 

PA 670 PROC SQR .* X1=PSC C5S3 : Y1 = A5C 15$ C/.23 3 

:S$ = SS CX33 

OP 680 PLOT X,Y:DRAHTO X,YI:DRAMTO XI,Y1: 

FILLTO Xl,V:ENDPROC 


LISTING 2 


ZE 

iee 

DIM 55(126) 

CO 

no 

NO-0 

UJ 

120 

RESTORE ieoee + 2**HO 

PO 

130 
2 , 

GRAPHICS 7:SETCOLOR O,O,O:SETCOLOR 
12,2:SETCOLOR 4,7,i6:EKEC GRAF 

HY 

140 

EHD 


LISTING 3 


05 iee GRAPHICS 7:SETCOLOR 0,0,0:SETCOLOR 
2,12,2:SETCOLOR 4,7,10 
MI 1600 COLOR JL : FCOLOR l:PLOT 84,49 : DRAMT 
O 8 4,4 2 : DRAMTO 79„42:FILLTO 79,49:CIRC 
LE 75,43,5:PAINT 75,43:PLOT 136,64 

DO lOOl DRAMTO 139,57!FILLTO 128,59:DRAHT 
O 82,59:DRAMT O 83 32 PLOT 72,43:DRAMTO 

67,47:i>RAMTO 65,45.DRAMTO 51,59 
KK 1002 DRAMTO 26,59:DRAMTO 26,6l:FILLTO 
29,64:PAINT 65,46:PLOT 118,58:DRAMTO 1 
18,56:DRAMT O 88,S6:FILLTO 88,58 
OX 1003 PI OT 117,55:DRAMTO 117,52:DRAMTO 

108,52:FILLTO 108,55:PLOT 105,55:DRAMT 

O 105,50:DRAMTO 102,5©;FILLTO 102,55 
MJ 1004 PLOT 121,35:DRAMTO 121,58:PLOT 40 

,30:DRAMT O 40,58:COLOR 3:FCOLOR 3:PLOT 

159,65.DRAMTO 0,65:FILLTO 0,79 


LISTING 4 


PF 10000 DATA \KMllO«7K+*iHKl^O Ł9 j C; |R; 

15 }-H+ |CZ |A- |3 ; I !*•--» 1GHI A iv:K8#l?14J 

1.7 i 2. hytt |y : b c «- 11 : 4 ^ft*Ofi 



W artykule „Dodatkowe 
klawisze” z numeru 1/89 
jest opisany sposob 
podłączenia klawiszy 
funkcyjnych. Jest to jednak 
sposob tylko do Atari 
8Q0XL SzuKając w Atan 
65XE podanych tam 
połączeń w przewodzie 
wielożyłowym znalazłem je 
zupełnie w innych 
miejscach. Na 
zamieszczonym obok 
rysunku pokazane są 
znalezione przeze mnie 
połączenia w Atari 65XE. 
Przypuszczalnie są one 
identyczne także w 130XE 
Chciałbym jednocześnie 
ostrzec, że należy bardzo 
uważnie i ostrożnie 
dodonywac przeróbki, 
ponieważ łatwo można 
uszkodzić połączenie 
klawiatury z komputerem. 

Andrzej Romanowski 





n 

i-i 

A 

W 

n 

i 

i 

X 

> 

I 

lii 

0 

□ 

I 


cn 

n5 

3 

n 


OJ 
i— 


ar 


Cl 

-J 


U 


in 

05 

s 

o 

H 




0- 


CD 

I 

O 

LO 

'-O 


OJ 

3 

OJ 

w 

1_ 

03 

TC 


3 

O 

X! 

OJ 

>-» 

o 

Ul 

03 


CO 


■8 


! 

£N 




Ki 

O 

I 

i". 

co 

! 

K) 

•T 


ra 

X 

OJ 

M 

tn 

Ł. 

OJ 


3 

fU 

"O 

c 


03 

€ 

Ol 

“O 

rH 

03 

3. 


aj 

03 

a. 


— + 


in 

o 

i 

K 

I 

K 

CO 


03 

CCl 


Ł. 

0) 

-a 

o 

cc 




«4- 

K 

O 

n 

i 

CM 

CN 


CO 


tn 

X 

o 

Ł. 

O 

X 

03 

tn 

>. 

6 

OJ 

r-4 

L. 

Cl. 


CD 

I 

E) 

5> 


in 


o 

a 

o 

co 


03 

IT 

aj 

pH 

£} 

O) 

cc 

-C 

u 

0) 


o 

3 


BAJTEK 7/89 9 


























































rrgiivv<VTVrfV¥VVinr 

GRAFIKA 
W KODZIE 
MASZYNOWYM 


Prędzej czy później przyjdzie 
czas na Twój pierwszy program 
w kodzie maszynowym. Po nim 
nadejdą następne, coraz to bar¬ 
dziej złożone. Ale pewnego 
dnia zapragniesz, by Twój pro¬ 
gram nie tylko pisał i liczył, lecz 
na przykład grał i rysował. 

Problemem muzyki w kodzie maszynowym, wyko¬ 
rzystującej zarowno wewnętrzny mini procesor dźwię¬ 
kowy spectrum, jak i prezentowany niedawno trzy ka¬ 
nałowy generator będziemy się jeszcze nieraz zajmo 
wac. Na razie skupmy się na grafice. 

Spotykana w najlepszych grach grafika tworzona jest 
przez doświadczonych programistów przy użyciu 
sprzętu szesnastobitowego Raffaelle Cecco, autor ta¬ 
kich gier, jak Exolon, Cybernoid I i II oraz Stormiord 
używa do pracy trzech komputerów Na Olivetti PC 
tworzy szkielet gry, na Atari 1040 ST — grafikę i muzy 
kę, zaś wszystko przelewa na Spectrum (i me tylko) za 
pośrednictwem jednostki systemu CP/M firmy Philips 
My me będziemy naśladować Raffaelle, me z powo¬ 
du braku sprzętu, czy umiejętności, lecz przede wszy¬ 
stkim z powodu braku dostępu do bibliotek? procedur, 
bez których nie powstanie żadna gra 
Na poziomie jednostkowego użytkownika Spectrum 
sprawę trudna jest nawet tworzenie grafiki wektorowej 
tzn złożonej z punktów i odcinków Tematowi temu 
poświęcimy nieco miejsca na łamach „Bajtka” lecz 
zacznijmy od sprawy najprostszej — płaskiej grafiki 
złożonej z punktów łuków odcmkow i okręgow 
Istnieję dwie możliwe do wyboru drogi Pierwsza po 
lega na przechowywaniu w pamięci swego rodzaju 
mapy z zakodowana treścią obrazu Tresc ta odkodo 
wywana jest przez odpowiedni program który identyfi¬ 
kuje częsc rysunku i odtwarza go po kolei 
Druga droga opiera się na kilku (-nastu) podstawo¬ 
wych procedurach zawartych gdzieś w pamięci, do 
których odwołuje się wykonywany program za każdym 
razem gdy ma coś do narysowania. 

Oba sposoby są dobre choc i tak niezwykle praco¬ 
chłonne w realizacji Pozostawiam to więc dociekliwym 
i upartym Czytelnikom 

Aby jednak pomoc im, by n e błąkali się po pamięci, 
postaram się przedstawić, jak wykorzystać w kodzie 
maszynowym zwykłe, znane z Basic a komendy Plot 
DRAW i CIRCLE 

PLOT jest najprostszą komendą do której odwołują 
się wszystkie pozostałe, służącą do rysowania komen¬ 
dy Jej obsługa znajduje się ROM-ie pod adresem 
#22E5 (dziesiętnie 8933). Nie radzę jednak nikomu, 
by siedzi! działanie zaczynającego się od #22E5 pro 
gramu, gdy/ uwikła się w ROM bez szans na wyplata¬ 
nie Planujemy wprawdzie w ,E3ajtku” kompletny opis 
ROM-u Spectrum lecz jest to sprawa dość dalekiej 
przyszłości. 

Parametrami wejściowymi komendy PLOT są współ¬ 
rzędne punktu który ma zostać zapalony. Współrzęd¬ 
ną poziomą umieszcza się w rejestrze B, zas pionową 
w C Aby oszczędzić sobie pracy, zaś mikroprocesoro¬ 
wi taktów zegara, dobrze jest wykonać prosta ode rację 
BC - B + 256 * C i programik 
LD B.128 
LD C,88 
CALL 8933 
RET 

zastępować: 

LD BC,22656 
CALL 8933 
REJ 

Raz czy dwa, nie ma to znaczenia, ale przy progra 
mach powyżej 2 KB różnica, główme w zajmowanej 

pamięci, jest wyraźnie widoczna 
DRAW czyli „ciągnij linię” jest komendą pozwalającą 
na wyrysowanie odcinka (właściwie wektora) o począt¬ 
ku tam, gdzie znajduje się ostatni postawiony punkt 
(zmienne systemowe COORDS — 23677 i 23678) do 
punktu, na który wskazują podane przy DRAW liczby 
— współrzędne wektora 
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Zawarta w ROM se procedura DRAW wymaga jako 
parametrów czterech liczb, zawartych w parach reje 
strow BC i DE Para BC przechowuje współrzędne 
wektora w liczbach bezwzględnych (bez znaku a więc 
ze znakiem +), zas DE znaki odpowiednich wspołrzę 
dnych w kodzie U2 (najstarszy bJ zapalony — znak -, 
zgaszony — znak +) wraz z zapalonym najmłodszym 
bitem W sumie więc DE przechowuje wartości funkcji 
SGN (sigmum) współrzędnych x i y z rejestrów B i C 
Postępowanie to trochę marnotrawne ale co z r obsc 

DRAW zaczyna ste od adresu #24BA (dziesiętnie 
9402) i narzuca jeszcze ledno ograniczenie Mianowi¬ 
cie zmienia zawartość pary HL Która pow nna bvc od¬ 
tworzona przed powrotem do Basic-a W związku z 
tym przykładowa procedura DRAW wyglądać .będzie 
następująco. 

LD (236771 255 
LD (23688), 175 
EXX 

PUSH HL 
EXX 

LD BC 22656 
LD D 255 
LD E 1 
CALL 9402 
EXX 
POP HL 
EXX 
RET 

Pozostała nam procedura rysująca okrąg Nic prost 
szego jej początek znajduje się pod adresem v2D23 
(1 1555) Przesyłanie parametrów wejściowych jest tro¬ 
chę nietypowe, za ł o mniej Kłopotliwe Polega tc na 
umieszczeniu na stosie kalkulatora trzech liczb które 
procedura CIRCLE odczytuje odpowiednio jako współ 
rzędne środka i promień okręgu Umieszczenie na sto¬ 
sie kalkulatora danej liczoy odbywa się za pośrednie 
twem procedury STACK A z ROM-u, zaczynającej się 
od adresu#2D28 (11560) Przesyła ona na stos kalku 
latora liczbę z akumulatora 

Przykładowe wywołanie procedury CIPCIE wyglą¬ 
dać będzie więc następująco (para H L’ również musi 
być zachowana!). 

Fx\ 

PUSH HL 
EXX 

LD A,128 
CALL 11560 
LD A 88 
CALL 11560 
LD A,80 
CALL 11560 
CALL 11555 
EXX 
POP HL 
EXX 
RET 

Jak pewnie wiecie w Basic u podając, przy DRAW 
trzeci parametr można uzyskać bardzo ciekawe efekty 
Jest to realizowane również i z poziomu kodu maszy¬ 
nowego za pośrednictwem osobnej procedury #2394 
(9108) Trzy parametry wejściowe przesyła się na stos 
ka,kolatora tuz przed wywołaniem tej procedury, podo¬ 
bnie jak w przypadku DRAW, należy tez pamiętać o za 
chowan? u pary rejestrów H L 

Na kon ec proponuję wklepanie programiku rysują¬ 
cego zabawną twarz Zaczerpnięty został z mieś ęczni- 
ka „S nelair User nr 75, zas jego autorem jest Damien 
Scattergood ekspert od ROM u Spectrum 

To tylko przygrywka do ogromnego tematu, jakm 
jest grafika komputerowa Istnieje tak wiele sposobów i 
tak wiele pomysiow ze nie sposob jest je tu nawet wy 
mienie Na raze zyczę powodzenia w zmaganiach z 
mim grat ką obiecując że powrócimy wkrótce do te 
matu grafiki wektorowej 

Marcin Przasnyski 
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REM GĘBA NA EKRANIE 

REM by Damien Scattergooó/SU 

BORDER O: PAPER O: INK 5: OVER 1: CLS 

CLEAR 29999 

FOR F-0 TO 131: READ A: POKE 30000+F A 
NEXT F 

RANDOMIZE USR 30000: PAUSF O 
DATA 217, 229, 217, 62, 100, 205 
DATA 40, 45, 62, i00, 205, 40 45 
PATA 62, 69, 205, 40, 45, 205, 45 35 
DATA 62, 68, 205, 40. 46 , 62, 116 
DATA 205, 40, 45 62, jU3. 205 
DATA 40, 46, 205 , ^5, 35, 62, 132 
DA^A 205, sO, 46. 62, i 16, 205, 40, 45 
DATA f> 2, 16, 205, 40, 45, 205, 45, 35 
DATA 62, 10O, 50, 125, 92, 62, 60 
DATA 60, 126, 92. 1, O, 32, 1 7, l, 1, 205 
DATA i 86, 36, 62, 96. 205, 40, 45 
DATA 62, 32, 205, 40, 45, 62, 2 
DATA 205, 40, 45, 62, 64, 50, 125 
DATA 92, 62, 64, 50, 126, 92,205 
DATA 148, 35, 1, 68, 116, 205, 229 
DATA 34, 1, 69, 1 17, 205, 229 
DATA 34. 1, 132, 116, 205, 229 
DATA 34, i, 133, S 17, 205, 229 
DATA 34,217,225,217,201 


JOMPM 

System operacyjny TOS dla 
ZX Spectrum charakteryzuje 
się m.in. hierarchiczną struktu¬ 
rą katalogu. Jego wadą jest ko¬ 
nieczność pamiętania, w jakim 
podkatalogu umieściliśmy 
dane. 

Wadę tę likwiduje poniższy program — „JUM- 
PER” Umożliwia on swobodną „wędrówkę” po 
podkatalogach, jak również wgranie w każdej chwili 
dowolnego programu lub danych (nagrywanych 

przez SAVE * „nazwa” CODĘ) Wymagane jest, 
aby program w BASIC-u posiadał rozszerzenie 
BAS, a zbiór danych — COD W p r zypadku napot¬ 
kania innego rozszerzenia wyświetlany jest komu 
nikat o błędzie (linia 5025), 

W celu wgrania dowolnego zbioru lub przejścia 
do podkatalogu, należy klawiszami 6 i 7 przesunąć 
migający prostokąt na nazwę zbioru (lub katalogu) i 
nacisnąć ” 0 ” Powrot do poprzedniego katalogu 
jest możliwy po wciśnięciu ” 1 ” 

Program należy zapisać na dysku przez: CLE¬ 
AR: SAVE * „START” LINĘ 10: ATTR * „START” 
i będzie on automatycznie wczytywany po naciś¬ 
nięciu RESET 

Większość liczb w programie zastąpiono przez 
wyrażenie z „VAL lub „PI", aby maksymalnie 
zmniejszyć ilosc zajmowanej przez niego pamięci 
— zajmuje on w ten sposób jedną jednostkę aloka¬ 
cji Nic oczywiście me stoi na przeszkodzie, aby 
rozbudować go według własnych potrzeb 

Jacek Zapała 


ł8K 6 8§e ER 7« ( ? T cCI : : P eif R a ^ PI 



*n-r C 8T. LET n »URL "6": PRINT 
#NOT PI;"6-DGL 7-GORA 

®rO* ,. l “££ wfot <*o ostatniego 

fc*ta o§u ££§ 

3° gpINT Pr“n , not PI; OUER 3GN 

6eep " 

‘ n >UAL "6" 

PRINT RT n,NOT PI; FLASH N 

21 £1' 22 er sgn PI: a*- LET n«n-S 
GN „PI; GO TO URL "30* SI 

Sf.. s $5i£ N !.J a ' 6) >"® ff pnd in 
KEYf= 'l" THEN DRAU *: RUN 

I ®:LT F JNKEY* = "6" THEN IF n<?UA 

be HoeTl^tfFerrtgK 

o 5 w£' J 35* i sP 50N 60 T 

. JE INKĘ?!-"©" THEN GO TO Ufi 

L "5000" 

70 GO TO ^AL "40 11 ĘB 
1000 LET n$»"": FOR X =NOT PI TO 
URL "8": LET S $sSCREEN$ <n,X). I 
F £$<>• " THEN LET n*an*+s* 

1015 NEXT X: LET n*-n*+"." 

1020 FOR X =URL "9" TO UAL "1_ 

LET S$=SCREEN* (n,X): IF SfiO" 
THEN LET n*«n t +s« MB 
1030 NEXT x in 

1040 IF OM”. THEN LET n»«"": L 
ET n»n-SGN PI SB 

1045 PRINT RT n.NOT PI; OUER SGN 
PI; FLASH NOT PI;e$ EH 
1050 RETURN j3SI 
5000 GO SUB UAL "1000" 

5010 LET rfian*(LEN nfi-UA“'3" TO 
LEN nl): IF r**".BAS" THEN LOAD 
*n fi (fi! 

5020 IF ffis".COD" THEN INPUT "Po 
daj RAHTOP iENTER-RAMTOP program 
owy) ", LINĘ gs: IF ga< >"" THEN 
LET g=UAL gg-SGN PI: LET laUSR " 
a"• POKE l,LEN ns: FOA z aSGN PI 
TO LEN n$: LET lal +SGN PI: POKE 
t,CODĘ n$(Z TO Z) - NEXT Z: CLEAR 
q LET nfia"". LET naPEEK US "a 
". FOR Z*SGN PI TO n: LET n«*n* + 
CHR; (PEEK (USR "a"+Z)) : N£XT Z: 
GO TO UAL "5030" 


5025 LET 3«*n«(LEN nł-UAL "3" TO 
LEN ri j) : IF ef<>".DIR" AND e$<> 
".COD" THEN CLS : PRINT "Wczytaj 
sobie ten program jax chcesz, 
ja n,e wiem, co z mm zrobić! 
": STOP iH 

5027 IF r$«".DIR" THEN LET dfiant 
(SGN PI TO LEN Ot-UAL "4"): GO S 
' : RUN 
LS : LOA“ 


UB *d 
5030 


«n*CODE 












Myślę, ze wiele osob widziało 
program, który ładuje się z tzw. 

licznikiem. 

Mam na myśli gry EXOLON, KANE itp Pod¬ 
czas ładowania wartość licznika zmniejsza się 
az do zera, gdy program jest już cały w pamięci 
Jest to o wiele bardziej eleganckie od zwykłych 
„pasków", gdyż licznik jest me tylko efektowny 
graficznie, ale także dobry „na nerwy”, ponie¬ 
waż w każdej chwili wiemy, ile czekania nam je¬ 
szcze zostało 

Przedstawiony program LICZNIK umożliwia 
ładowania programów w ten właśnie sposob 


Głowna częsc kodu maszynowego pochodzi z 
loadera do programu BOULDER DASH IV, re¬ 
szta to przystosowanie do ładowania według 
danych z nagłówka, tak, by użytkownik mógł ko¬ 
rzystać z programu bez znajomości assemblera. 
LICZNIK znajduje się przy końcu pamięci, od 
adresu 64500 do 69252. Uruchamia się go ko¬ 
mendę RANDOMIZE USR 65100 Program 
wczytuje wtedy nagłówek (pierwszy napotkany) 
pod adres 65082 i ładuje tylko bloki typu PRO¬ 
GRAM i BYTES, nie akceptuje tablic 

LICZNIK, jak juz wyżej wspomniałem, umiejs¬ 
cawia dany program w pamięci na podstawie 
danych w nagłowKu Jeżeli podczas ładowania 
wystąpił błąd, LICZNIK wraca do BASIC a (kon¬ 
kretnie do miejsca wywołania, może więc rów¬ 
nież wrócić i kontynuować wykonywanie kodu 
maszynowego) Nie przerywa działania progra¬ 
mu, tylko umieszcza w komorce 65099 wartość 
0 (normalnie 255) 

Jeżeli me odpowiadają nam atrybuty licznika 
(standardowo czarne litery na białym tle), to 


dzięki POKE 64910, (wartość negatywu atry¬ 
butu) możemy je zmienić 

Od adresu 64562 począwszy znajdują się 
kształty cyfr 6 w negatywie) od zera dcf dziew ąt- 
ki kolejno. Kształty można przedefiniować we¬ 
dług własnego upodobania, podobnie jak two¬ 
rzymy znaki graficzne (UDG). 

Jeżeli chcemy korzystać z programu LICZNIK 
z poziomu assemblera, to podajemy parametry 
takie same, jak dla systemowej procedury łado¬ 
wania, tj. 

LD IX, adres początku 
LD DE długość 
LD A, FFF 
SCF 

CALL 64500 

LICZNIK me jest programem krótkim, ale my¬ 
ślę ze warto zdobyć się na odrobinę cierpliwoś¬ 
ci i wpisać go 

Jacek Marczewski 


10 DflTft 6*500,64 

60 DATfi ••F5D5EDS32CFCCD0FFED1F 
137CDSftFCS>15827D9C33F05fiE??23130 
B7BB120F6C340" 

30 DATA “ 3AFE*E*FFF000115FCFE6 
0310003*3*F***52020202020S003020 
0640064FEC6D*" 

*0 DfiTfi "BflBfiBABftCBFEFEeECEEEE 
EEES2FEFEC6BFIF6EEDE82FEF682F6E6F 
R8RC6FEFEF638" 

50 DfiTfi "E6D6B682F6FEFE82BE86F 
fiBfiC6FEFE£6DE86BfiBftC6FEFE82FfiP6F 
6EEEEFEFEC6fl8" 

60 DfiTfi "BfiC6BRBfiC6FEFEC6BflBfiC 
2FfiCSFEFEC6BfiBflBfiBRC8FEl*0815F3D 
90E00D93E0R0C" 

>0 DfiTfi "D3FEDBFE1FE820F6014F© 
F00CDS0FD30FA21150*10FE2B7CB520F 
9CD1CFO30EBR8" 

80 DAT FI "069CCD1CFD30E43EC6B83 
6E024S0F106C9CD20FD30D578FED430F 
♦CD20FDD0D95C" 

90 DATA •3A1AFC4F321FFCD926000 
61.0181F032007300FDD7500180FCB11A 
DC0791F*F1302" 

100 DATA '1807DD7E00ADC0DD231B0 
8t 6B22E01CD1CFDD03ECBB8CB1B06B0D 

203FD7CAD6760" 

l10 DATA "7AB3S0CA7CFE01C9CD20F 
OD0C33BFD0*C83E7FDBFE1FD0A9E6202 
8F3792F4PE60S" 

160 DATA ■•07F608D3FE37C9D979B72 
8*0211FFC357E285BFE0530*2211BFC3 
*2C6C355A1B6C U 


130 DATA "FC7EC6368F16FC2A1DFC1 
A771C6*1A771C2*IA771C6*1A771C2*1 

1*0 DATA "1C2*1A771C2*1A7709C32 
3FD061710FE3E00ED**A7D9C323FD3E* 
732FA5A32FB93" 

150 DATA "SA32FC5A3SFD5A6323060 
DC332FD064FEDS816FC2A18FC1DF2B9F 
D5815060510*0" 

160 DATA ”FE7EC3ECFD7AE607CAD1F 
D15F6D3FD502D3A00803A00803A0080C 
3ECFD7E7E7DCE" 

170 DATA E607CAE4FD2DF2E6FD682 
5ED**C3ECFD7E7E7CE607280165ED531 
6FC2218FC2160" 

180 DATA '15FC221BF021FE50261DF 
C3E40321FFCED*4ED**E0**A7D9C323F 
D2A2CFC060513" 

190 DATA "CB3CCB1D10PA1119FC3EF 
F01E8033CB7ED4230FA09678787124D* 

200 DATA “7BFE1520E4C920284329* 
A*1*D53*F*65*27383920202000F3F5C 
5D6E5DDE5FD41 *’ 

210 DATA 'E508D9F8C5D5E5D908DD2 
13AFE1111003E0037CD56053A3AFEFE0 
02331FE0320FA" 

220 DATA “E8DD2A47FEED5B45FE3EF 
F37CDF4FB3806AF324BFE18053EFF32* 
BFED90SEID 1BF" 

230 DATA "C1F1D908PDE1DDE1EID1C 
1F1FBC9ED5B538C2A595C2BCDE5192AB 
95C2BED4B46AA" 

2*0 DATA "FECD551023ED5B49FE192 


24B5C3A48FEE6C0200A2A47FEAF22425 
C3244SCDD2AD1' 

250 DATA "535CED5B45FE3EFF37CDF 
4FB38A918A10*" 

260 REM 
270 REM 
280 REM 
290 REM 
300 CL EAR 6**99 

318 PRINT "URUCHOMIENIE - RAND. 
USR 65100" 

320 00 SUB 9990 
"LII 


330 SAUE 


:CZNXK”CODE 6*500,75 


3*0 STOP 
9900 REM 
9991 REM 
9902 REM 

9993 READ A,S: FOR P«10 TO S«10 
STEP 10 
999* READ Lf: 
a • LET K>2 

9995 LET R*»L*(K-1): LET Bt«L«(K 
) 

9996 LET C*(C0DE 
i!l * «+CODE B 

9997 IF K<L TH 
«S+C: LET K»K+2: 

0 9995 

9998 IF 3-356#INT 


LET L»LEN L«: LeT 

(K-l) : LET Bt«L«(l 

DE fl*-*8-(7* (A«>"0 
«-*8>(7«(Bf>"0") ) 
EN POKE A,C: LET S 
LET AaAtl: 00 T 


(S/256)<>C THE 
N PRINT “BLAD U LINII ";F*10: ST 


OP 

9999 NEXT 


F: RETURN 


PERKUSJA 


Amstrad, po przejęciu fir¬ 
my Sinclaira, nie tylko 
utrzymał produkcję ZX 
Spectrum 128, ale wprowa¬ 
dził na rynek dwa nowe mo¬ 
dele ZX Spectrum oznaczo¬ 
ne +2 i +3, zgodne ze sta¬ 
rym 128 KB, a nawet wypo¬ 
sażone w tryb emulacji 
Spectrum 48. 

Te trzy komputery rozmą się od 
swoich młodszych braci me tylko pa¬ 
mięcią, ale i układem do generacji 
dźwięku. .Gumiak’ nigdy me miał 
zbyt wielkich możliwości dźwięko¬ 
wych, ale juz w ZX Spectrum 128 
wprowadzono trojkanałowy generator 
AY 3—8910, który wcześniej zastoso¬ 
wany był w ośmiobitowych maszy¬ 
nach Amstrada 

Zwiększone mozl wosct muzyczne 
Spectrum wykorzystywane są w wielu 
grach, powstałych w 1987 roku i póź¬ 
niej Istnieje także kilka orogramow 
muzycznych (ja miałem do czynienia 
na razie z trzema — he Musie Box 
128, Musie Studio 128 i Mozart) 

Po takim wstępie chciałbym zapre¬ 
zentować procedurę, która może 
przydać się tym wszystkim, którzy w 


swoich programach chcieliby wyko¬ 
rzystywać dźwięki z generatora a zwy¬ 
kła instrukcja PLAY juz im me wystar¬ 
cza Po uruchomieniu programu 
otrzymujemy do dyspozycji dziesięć 
dzw ękow o perkusyjnym brzmieniu 
Większa jego częsc jest napisana w 
kodzie maszynowym lecz do prawi¬ 
dłowej pracy potrzebny jest choc frag 
ment programu w Bas cu — co naj¬ 
mniej od linii 200 Pomysł został za¬ 
czerpnięty z programami MICRO 
RYTHM i jest to jego najbardziej upro¬ 
szczona wersja 
Op s programu 

5—80 przepisanie do pamięci 
kodu maszynowego 
100—130 przepisanie do pamięci 
kodu dźwięków 

200—210 odtwarzanie dźwięków 

220 wyłączenie generatora 

250 kody dźwiękowe 

300 graficzne odwzorowanie ak¬ 
tualnego dźwięku 

Najważniejszą częścią programu jest 
kod maszynowy, umieszczony w 
dwóch niezbyt odległych od siebie 
miejscach pamięci Ze względu na ta¬ 
kie rozmieszczenie konieczne jest 
użycie instrukcji skoku. Z tego powo 
du kod me jest relokowalny. 

Program „Perkusja” może być uru¬ 
chomiony także na Spectrum 48 z do¬ 
łączonym generatorem dzwęków i 
dlatego dźwięk wyłączany jest instruk¬ 
cjami OUT a me PLAY 

W linii 50 umieszczamy cyfry od 0 
do 9 — dane dla perkusji Trzeba jed¬ 
nak pamiętać, by na jej końcu znajdo¬ 
wała się liczba 255 i cyfr me było wię¬ 
cej mz 280 Potem można juz urucho 
mie procedurę instrukcją RUN. Kom¬ 


puter zamilknie na kilka chwil, by 
wczytac kod maszynowy 

Przy prawidłowym przepisaniu pro¬ 
cedury, w lewym górnym rogu ekranu 
powinno pojawić się słowo ZAPIS 
Oznacza to, ze komputer przystąpił do 
przepisywania kodow dźwięków Czas 
wykonywania tej operacji zalezny jest 
od ilości cyfr w linii 250 Następnie 
także w lewym górnym rogu pojawi 
się napis ODTW oznaczający rozpo¬ 
częcie odtwarzania zapisanych dźwię¬ 
ków Ponadto na środku ekranu poja¬ 
wią się cyfry od 0 do 9 i czarny pas, 
który będzie wskazywał numer dźwię¬ 


ku odtwarzaneao w danym momen¬ 
cie 

Program jest tylko propozycją wy¬ 
korzystania zwiększonych możliwości 
komputera ZX Spectrum 128 i od nie¬ 
dawna, rowmez 48. Jego rozbudowę 
pozostawiam Czytelnikom Chciałbym 
jednocześnie zachęcie Was do ek¬ 
sperymentów z tym komputerem 
Często ich efekty są zadziwiające Po¬ 
słuchajcie tylko muzyki z takich gier 
jak TURBO BOAT czy PROFESIONAL 
BMX SIMULA OR i spróbujcie ułożyć 
podobne Życzę powodzenia 

Michał Sobieszuk 


5 LET S=0 

10 FOR 1-49439 TO 49637: READ a LET S-S+A POKE i a. NEXT i FOR 1-49692 TO 4 
9790 READ a LET S-S+A POKE i.a NEXT i 
20 IF S<>18331 THEN PRINT "BLAD I!!": STOP 

30 DATA 0.0.56.7,15,0.56.7.12 0.5b 7.9.0.56.7.5.0,56,7,2.2 211.26,15 3.2,0.14. 
3 ..49.6.13.3.96.12.12.3.143.17.11.1,12.1.12 1.12.1.8 1,12.1.5.1.12,1.1, 1,12,1,0 
35 

40 DATA 1.244.26 15 1.254,0.14 2.8.6.13.2 18.12.11.2.28.17.10.3,232.15.15 3,13 
2.0.13,3.32.15.11.2,188,0 9.2.88.15.7.1.244,10.15.1.246.30.13.1,244.10.11.1.246. 
30 

45 

50 DATA 9.1 244.10,7.0.100,0.15.0.110.31.14.0.120.15.13,0.110 31.11.0.100.0,9, 
2.111.14.15.2.158,20.14.2.205,26.13.2.252.0.12 3,43.6.11,2.211.20.15.3.2.25,12,3 

55 

60 DATA 49,31.9,3.96.5.5,3.143.11.2.0.200.31.12,0 210.15,11.0,220.10.9,0.210.5 
7,0,200,58.117.194.254.19,200,58 118,194,203.39.203,39,71 135,135 128.95 
65 

70 DATA 22.0,33.32.193.25.58.117,194,95.22.0.25.14.253 6,255.52.1.237.121.6.19 
1.126.237.121.35.6.255,62.0,237.121.6.191.126,237.121.35.6.255.62.6.237.121,6 

75 

80 DATA 191,126.237.121.35.6.255.62.8,237,121.6.191.126,237.121.58,117.194,198 
4.50.117.194.201.0.0.194,196.4.50.126.194.201,12 
85 

100 STOP PRINT AT 0.0."ZAPIS": FOR 1-49152 TO 49438 READ s 

110 IF s-255 THEN GO TO 200 

120 IF s>-0 AND s<«9 THEN POKE i.s 

130 NEXT i 

200 PRINT AT 0.0,‘ODTW "- FOR 1-0 TO 9 PRINT AT 9,(i*3) i NEXT i 
210 READ aS FOR 1-49152 TO 49438- LET z-PEEK i: POKE 49781.0: POKE 49782 z. PR 
INT AT 10.0.a${l TO 3*(9-z)+1)i" FOR a-0 TO 4 RAND 

OMIZE USR 49692: PAUSE 1- NEXT a NEXT i 
220 OUT 65533 7: OUT 49149,255 
230 GO TO 100 
250 DATA 255 
300 data 
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Generator dźwięku zwany 
w skroc e AY zadziwił 
wszystkich Trzy kanały i to 
w dodatku stereo zadowolę 
najhardziej wybredne ucho. 

Tak więc muzyka Spectrum porów¬ 
nywalna jest juz z muzykę Amigi, me 
mówiąc o tym ze bije na głowę Atari, 
Commodore i inne komputery, które 
dotąd zdawały się dominować 

Ale jest jedno „ale" Każda gra na 
Commodore wykorzystuje jak nie trzy 
to dwa kanały swego procesora 
dźwięków Podobnie jest z Atari Na ¬ 
tomiast w przypadku Spectrum tylko 
część gier obsługuje generator. Wpra¬ 
wdzie od momentu wprowadzenia na 
rynek modelu 128 większość gier po¬ 
siada rozszerzone możliwości muzy¬ 
czne, lecz częsc z nich ujawnia się 
tylko na Spectrum 128 

Nie jest jednak źle Powstają wciąż 
gry i programy muzyczne działające 
na Spectrum 48 z dołączonym gene¬ 
ratorem Poniżej przedstawiona jest li¬ 
sta najpopularniejszych z nich 

Ostatnio rozpowszechniona jest 
moda na „wyciąganie” muzyki gier i 
umieszczanie w jednym programie 
kilkunastu takich ekstraktów Moda ta 
pojawiła się na giełdzie „Bajtka” i stąd 
też wyszły pierwsze tak-e programy. 

Celuje w tym miły człowiek-hacker 
podpisujący się Chris Aby urozmaicić 
i tak wspaniałe efekty dzwiękowo-mu- 
zyczne, w programach swoich umie¬ 
szcza bardzo długie, przewijające się 
napisy, kogo to on me lubi i który z ha¬ 
ckerów giełdowych jest beznadziejny 
Komentarze te pisane są niby po an¬ 
gielsku, przy użyciu czasu Simple 
Present i pięciu obraziiwych słów, w 
różnych mutacjach 

Postępowanie takie me jest godne 
naśladowania Nieprzyjemne są so¬ 
czyste komentarze i pomijając war¬ 
tość programów pod względem mu¬ 
zycznym, są one haniebne Jeśli 
Chris w istocie chce błyszczeć może 
spróbuje sposobow mniej rażących 
otoczenie 

Kto chce słuchac dobrej muzyki, 
musi więc ją sobie albo sam napisać 
(polecam , Wham — The Musie Box 
128" — opis wkrótce w „Bajtku") lub 
korzystać z gier, najlepiej z poniższej 
listy 

Ace II 

After Burner 
Agent X II 
Amaroute 
ATF 

Bear a Grudge 

Błonic Commando 

Boulder Dash Construction Kit 

Bubble Bobble 


Chronos 
Cybernoid 
Cybernoid II 

Daley hompson s Olympsc Challen¬ 
ge 

Death Ride 
Death Stalker 
Defcom 

Eagle s Nest 

Enduro Racer 
Exolon 

Foxx Fights Back 

G I Fłero 

Gryzor 

Hot Shot 

Hydrofooi 

Ikar Warr ors 

International Karate + 

Marauder 
Mask II 
Motos 

Nether World 

Neverendmg Story 

Outrun 

Pacland 

Pacmania 

Platoon 

Profesionai BMX Simulator 

Raw Recruit 

Rex 

Robocop 
Sigma 7 
Skate Crazy 

Soccer 

Spitting Image 

Supertest 

Tai-Pan 

Target Renegade 

Thunder Cats 
Tiger Road 

Turbo Boat 
Venom 

Vindicator 

Vixen 

Where Time Stood Still 

Wizbail 

Xenon 

Marcin Przasnyski 



IIKRVflKATOR 

-PO RAZ TRZECI- 

Oto trzecia wersja programu „Weryfikator”, służęcego 
do kontroli wpisywanych list ingów. Uważam, iz jest to wer¬ 
sja jak na razie najdoskonalsza. Nie zajmuje obszaru przez¬ 
naczonego na' grafikę użytkownika, współpracuje z Interfa- 
ce 1 i jest krótsza od wersji II. Dodatkowo suma kontrolna 
wyświetlana jest przed numerem linii, zaś zmieniając kod 
w linii 130 można uzyskać wydruk sumy w nawiasach. Jest 
to szczególnie ważne w przypadku używania drukarek poz¬ 
bawionych możliwości drukowania w negatywie. 

Podobnie, jak pozostałe wersje, tak i ta oblicza sumę ko- 
dow instrukcji modulo (256) pomniejszoną o 9. 

Andrzej M. Grossman 
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W układzie dziesiętnym ope¬ 
racje dzielenia i mnożenia 
przez dziesięć polegają w wiel¬ 
kim up c szczeń u na przemie¬ 
szczaniu kropki dziesiętnej od¬ 
powiednio w lewo i prawo o je¬ 
dną pozycję. Tak jak dzielenie i 
mnożenie przez dziesięć są ba¬ 
zowymi działaniami w dziesięt¬ 
nym układzie liczenia, tak w 
układzie dwójkowym odpow e- 
dnikiem są dzielenie i mnoże¬ 
nie przez dwa. 

Wykonujemy je równie prosto przez przemiesz¬ 
czenie bitów w baje e (lub bajtach jeżeli liczba zapi¬ 
sana jest w więcej mz jednym bajcie) w prawo lub 
lewo 

Zapiszmy w układzie binarnym liczby 50, 100, 
200 dane dziesiętnie Otrzymamy 

50— %00110010 
100 — %01100100 
200 — % 11001000 

Jak widać przy podwajaniu liczb bity w bajcie 
przemieszczają się w lewo o jedną pozycję, przy 
czym na miejsce najmłodszego bitu w bajcie wpi¬ 
sywane jest zero Instrukcją służącą do takiego 
mnożenia przez dwa jest ASL (Arithmetic Shift 
Left) lub inaczej arytmetyczne przesunięcie w 
lewo Gdybyśmy wpadli na pomysł pomnożenia 
przez dwa otrzymanej liczby 200 to wyniknie pro¬ 
blem Jak wiemy liczby 400 me da się zapisać w je¬ 
dnym baje e Nastąpi więc przepełnienie sygnalizo¬ 
wane ustawieniem znacznika przeniesienia na 1 
(C = 1) Tak więc można powiedz ec, ze instrukcja 
ASL powoduje wpisanie wartości 0 do najmłodsze¬ 
go bitu w bajcie i wpisanie najstarszego bitu z bajtu 
(odpadającego po wykonaniu mnożenia) do znacz¬ 
nika przeniesienia C 

Dobrze by było gdybyśmy dysponowali instrukc¬ 
ją działającą podobnie do ASL, lecz wpisującą do 
najmłodszego bitu me zero, lecz wartość znacznika 
C aka instrukcja umożliwiłaby nam prowadzenie 
obiiczen na liczbach zapisanych w kilku bajtach In¬ 
strukcją taką w procesorach 65xx jest POL (Rotate 
ieft) — rotuj w lewo Działa ona tak jak to przedsta¬ 
wiono na rysunku 

Przykładowe użycie tych instrukcji (pamiętajmy, 
ze operacje arytmetyczne wykonywane są wyłącz- 
me w akumulatorze). 

LDA $2750 
ASL lub ROL 
STA $2750 
BRK 

Program ten powoduje przemnożenie przez dwa 
zawartości komórki pamięci o adresie $2750 i zapi¬ 
sanie wyniku do tej samej komorki 

Jeżeli naszym celem jest pomnożyć liczbę zapi¬ 
saną w trzech bajtach ($2750 $2752) przez np 4 
to musimy napisać następujący program (Lś 
ST1NG1) Mnożenie przez 4 to dwukrotne mnoze- 
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02729 9D 50 27 STA $2750.X 

0272C 88 DEY 

0272D DO E3 BNE $2712 

0272F 00 BRK 

me przez dwa, dlatego tez do rejestru Y służącego 
dalej jako licznik wpisana zostaje wartość dwa Aby 
me używać dwóch instrukcji ASL i ROL, ustaw amy 
znacznik przeniesienia na zero, a w związku z tym 
pierwsza instrukcja ROL zadziała tak jak ASL, czyli 
do najmłodszego bitu w bajcie wpisane zostanie 0 
Następnie trzy razy oowtarzana jest sekwencja za¬ 
ładowania zawartości komorki do akumulatora, po¬ 
czynając od najmłodszego bajtu, dokonania mno¬ 
żenia na tym bajcie, zwiększenia zawartości reje¬ 
stru indeksującego X o jeden Następnie liczn k Y 
jest zmniejszany o jeden i sprawdzony zostaje wa¬ 
runek czy mnożenie zostało wykonane dwa razy 
Jak widać, tak jak większość pierwotnych wersji 
naszych programów tak i ten jest mało uniwersalny 
Jedyna rzecz jaką możemy sterować to ilosc wyko¬ 
nywanych mnozen przez dwa — zawartość rejestru 
Y Aby uogoin c ten program oraz aby mieć pre¬ 
tekst do wprowadzenia czterech nowych instrukcji 
powstał program znajdujący się na LISTINGu 2 
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Jaka różnica — spytacie Mimo ze jest on dłuzszy 
od pierwszego, to nie ulegnie on już żadnym wy¬ 
dłużeniom — jest uniwersalny Ilość mnozen regu¬ 
lowana jest zawartością rejestru .Y, a ilość bajtów, 
które ulegną wymnozemu wynika z instrukcji w linii 
$2726, w której następuje porównanie liczby okre¬ 
ślającej ilość bajtów z ilością dokonanych juz wym- 
nozen 

Program wykorzystuje podprogram wykonujący 
pojedyncze mnożenie trzech bajtów przez dwa W 

podprogramie tym pojawiają się instrukcje operują¬ 
ce na stosie Instrukcje PHP i PHA powodują zapi¬ 
sanie zawartości odpowiednio rejestru słowa stanu 
i akumulatora na stosie Instrukcje PLP i PLA powo¬ 
dują ściągnięcie ze stosu i załadowania do rejestru 
słowa stanu lub akumulatora odpowiedniego bajtu 
Stos działa według zasady LIFO (Last In First Out) 
czyli ostatnia wartość zap sana na stosie będzie 
pierwszą odczytaną z mego Dlaczego użyto tych 
instrukcj w tym podprogramie 9 Otóż jak juz wspo- 
mn ałem w celu ich prezentacji i pokazania sposo¬ 
bu działania w programie jak również w celu ugrun¬ 
towania wcześniej nabytej wiedzy dotyczącej ope¬ 
racji logicznych Oczywiście program ten można 
napisać prościej Pozostaw am to jednak Wam Jak 
pam ętamy przy mnożeniu za pomocą instrukcji 
ROL ważną rolę odgrywa znacznik przeniesienia C 
natomiast przy porównywaniu CPX jego wartość 
może się zmienić co może nmec wpływ na dalsze 
obliczenia Dlatego przed porównaniem zapamięta¬ 
łem cały rejestr słowa stanu na stosie, przepisałem 
go do akumulatora (gayz bezpośrednio rejestru 


słowa stanu me można załadować do akumulatora) 
a następnie zapamiętałem zawartość akumulatora 
w komorce pamięci o adresie $2760. Następnie 

dokonałem porównania i nową wartość zapamięta¬ 
łem na stosie, przeniosłem ze stosu do akumulato¬ 
ra i dokonałem „połączenia obu rejestrów słowa 
stanu dbając o to by zmianie me uległy znacznik 
przeniesienia C i znacznik zera Z Reszta programu 
jest taka jaK w pierwszym programie zawartym na 
LSSTiNGUI 

Po wpisaniu każdego z tych programów należy 
zadbać o to by odpowiednie wartości znalazły się w 
komórkach o adresach $2750 $2752. Pamiętajmy, 
ze wartości wpisujemy poczynając od najmłodsze¬ 
go bajtu I tak jeżeli wpiszemy #$24 do komorki 
$2750 #$66 do $2751 i #$13 do $2752 to po wy¬ 
konaniu programów komork te będą zawierać war¬ 
tości #$4D #$98 #$90 Sprawdźcie ręcznie czy 
takiego wyniku należy oczekiwać. 

Mamy więc programy umozliwające mnożenie 
przez wielokrotność dwóch Mnożenie przez dzie¬ 
sięć me powinno byc o wiele trudniejsze. Mając 
daną liczbę L mnożymy ją przez dwa i zapamiętuje¬ 
my w jakiejś komorce o adresie XXXX Następnie li¬ 
czbę mnożymy dwa razy przez dwa (razem 8L) i 
dodajemy zawartość komorki XXXX (8L+2L=10L). 
Można tę sekwencję uproście zakładając, ze liczba 
L była zapisana w komorce o adresie XXXX wtedy 
L przepisujemy do akumulatora A mnożymy za¬ 
wartość przez 4, dodajemy zawartość komorki o 
adresie XXXX i całosc mnożymy przez dwa Razem 
otrzymujemy również 10L. Proponuję napisać wła¬ 
sne programy mnożące przez dziesięć i porownac 
je z rozwiązaniami LISTING 3 i LiSTING4 Ambit- 

l DA 4 * t X 

,'łNL 
-.3 I t i 
i-i DL 
HbL 

ul >L v X >. X X 
i' Fu % - % X X 


A Dl 
u bL 

A 1 'i 4 D> 

A i. 

mejszym proponuję zmodyfikować program z LI¬ 
STINGu 2 i wykorzystać go jako procedurę w pro¬ 
gramie mnożącym przez 10 
Jako zadanie domowe proponuję napisać pro¬ 
gram wykonujący mnożenie dwóch dowolnych 
liczb całkowitych jednobajtowych, dających wyniki 
mieszczący się w dwóch bajtach 
Możemy teraz przejść do dzielenia Przy tym 
działaniu dysponujemy podobnymi instrukcjami do 
ASL i ROL lecz „działającymi w drugą stronę”. 
LSR (Logic Shift Rght) logiczne przesunięcie w 
prawo i ROR (ROtate Right) rotuj w prawo LSR po¬ 
woduje wpisanie wartości 0 do najstarszego bstu w 
bajcie i przepisanie wartości spadającej z młodsze¬ 
go bitu do znacznika przeniesienia C 
ROR odwrotnie do ROL powoduje wpisanie do naj¬ 
starszego bitu wartości znacznika przeniesienia 
Jak wspomniałem, operacje mnożenia i dzielenia 
wykonywane są w akumulatorze, tak jak i pozostałe 
operacje arytmetyczne. Istnieje jednak możliwość 
wykonania odpowiedniej instrukcji bezpośrednio 
na wybranej komórce pam ęci o określonym adre¬ 
sie Odpada wtedy konieczność przepisania zawar¬ 
tości komorki do akumulatora w celu np. wykonania 
mnożenia Możliwa jest zatem instrukcja LSR 
$25DF Kiedy instrukcje przesunięcia lub rotacji 
wykonywane są na bezpośrednio na pamięci, to w 
rejestrze słowa stanu dopwiedmo do wyniku zmie¬ 
niane są znaczniki Z N C Często spotykałem się z 
pytaniem, dlaczego odpowiednie instrukcje zawie¬ 
rają słowo „logiczny lub „arytmetyczny 9 Logicz¬ 
ny oznacza, że prawdopodobnie utracimy znak li¬ 
czby (jeżeli wykonujemy dzielenie przez dwa ze 
znakiem), a arytmetyczny oznacza, że prawdopo¬ 
dobnie znak ten będzie uratowany Jest to tylko 
kwestia terminologii, gdyż bity w bajtach przemie¬ 
szczają się tak jak spodziewamy się tego 

Dominik Falkowski 
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AMIGA 

UPS & TRICKS 


Wśród niezliczone} liczby 
ciągle pojawiających się 
książek do komputerów 
Commodore Amiga wybra em 
t# właśnie, gdyż czy to dla C64, 
czy C-128 książki Opatrzone 
tym tytułem stawały się 
zawsze prędko bestsellerami, 
i tymi razem wydawcą jest 
wszystkim dobrze znana 
DATA-BECKER. Książka to 
opasłe tomiszcze zawierające 
ponad 500 stron podzielone 
na 17 rozdziałów traktujących 
o Amiga BASIC, DOS, ikorfacb, 
języku maszynowym, 
operacjach wejścia i wyjścia o 
budowie samego sp^ętu 
(hardware) i inne. Każdy | 
rozdziałów poruśza obszernie 
wiele różnych ciekawych 
tematów np. w rozdziale o 
Amiga BASIC Tnożemy się 
dowiedzieć o tworzeniu 
okienek b ramek, grafice 
trójwymiarowej w oparciu o 
HAM (Hołd and Modify , 
zmianie kolorów, rysowaniu 
na ekranie monitora w oparci*! 
o inne układy współrzędnych, 
superszybkiej grafice 
Wektorowej, 0 drukowaniu itp. 
Każdy z tematów jest 
uzupełniony licznymi 
przykładach i programów. 
Podane są również oddzielne 
procedury realizujące 
określone .operacje. Moim 
zdaniem w książce jest za mało 
rysunków i zdjęć ekranów, 
któro często ułatwiają 
zrozumiehie wykładanego 
materiału. W tego typu 
książkach trudno jest nawet 
wspomnieć o wszystkich 
zawartych w niej tematach, 
gdyż każdy z nich (a jest ich 
mnóstwo) to parę stron w tej 
książce. Myślę jednak, że^Tips 
Tricks można pdteció 
wszystkim, którzy podstawy 
programowania w Amiga 
BASIC mają już za sobą a 
poszukują sposobów i 
sposobików na rozszerzenie 
możliwości tego komputera — 
znajdą na pewno odpowiedź 
na szeręg nurtujących eh 
problemów. Cena puołikacji 

59DM. 

Amićja Tips & Tricks 
DATA DECKER GmbH 
Nferowlngerstr £0 
4000 Duśseldbti 


COMMODORE 

64 


Z są f li M t krok on iputery 
Wydawnictwa Naukowo 
T phroćzn ioo ju az*ła się w 
ubiegłym roku ksiuzk&poćwięcf naf 
w całości popularnemu qq łym 
świście komputerowiCom m oddre 


. 1 ■. , X» u ii * « 577^ 


w wersji polskie/cznej 
st nąnaszym rynku dum is 
ićh przybywa. Jednak potrzebne 
informacje sącz: sto rozproszone 
po wieki publikacjach ! dotarcie do 
hłch Jeąt bardzo Utrudnione. 
BohdartFrelek (alitOfikślążki 
Commodore 64) w swojej książce % 
zebrał podstawowe Informacje 
dotyczące komputera >64.0 oleił* 
jej budowę, wykorzystanie oraz 
‘Spółpra z ui ąd tniami 
zewnętrznymi. Wspomniał nawet o 
możliwości podłączenia C-64 do 
IBM. Opisał programowanie C-64 
w języku BASIC (w:wersji dla 
po czątkujaoych f bardziej 
zaawansowanych) i Asemblerze. 
Przed; ta wfmożliw© c! uzyskania 

efektów dżWlękotyyCh i 

graficznych Pooał równteż 
informacje o mikrokomputerach 
VlG-2O, C-16* 4^128 

Książką ta stanowi kompendium 
wiedzy" o C-64 i byłaby n « 

cenną pozycju m półkach 
uży §wńik lpi eró 

commodore gd by ni 
kontynuacja złej tradycji 
terminologii komputerowej 
stosowanej w polskich ksfążkaó% 
Spierać się można ćó dó tego czy 
w infprmatyceuźywric wyra z e n 


... zepny) czy 
oryc nalnych brzmień yoystićk), 
ale wszyscy zgodni jesteśmy ca 
do tego, że wyrażeńjych nie Kai eży 
mieszaćfwięc albę joystick albo 
manipulator dm^kowy Jeżeli w 


ładowacz na określenie loadera? 

Drugą sprawą są niektóre 
stosowane termińy: interpretator, 
syntetyzator, grafika nisko/ 
wysokorozdzielcza i parę innych. 

Myślę, że już dość dawno 
wypisano się odnośnie tego, że 
mówimy interpreter języka 
programowania czy tryb wysokiej 
rozdzielczości ł szkoda, e młodzi 


książki p.Frelka zaczną od takich 
niepoprawnych dziwolągów. 
Jednak w sumie z czystym 
sumieniem mogę polecić książkę 
wszystkim tym, którzy z 
Commodore czy z 
programowaniem kiedyś się 
zetknęli. Nie przyswoją oni sobie 
bowiem złe[ terminologii a wyniosą 
dla siebie dużo nowej wiedzy 
zawartej w tej książce. 

Commodore 64 Bohdan Frelek 
WNT 1986 Cena 750 zł 
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Wśród wielu modułow (kart) 
dołączanych do C-64 rodzina 
FINAŁ CARTRIDGE jest chyba 
najbardziej popularna. Parę lat 
temu polski rynek czy raczej 
giełdę podbił FINAŁ CARTRID¬ 
GE II, dziś mam przyjemność 
przedstawić Czytelnikom jego 
młodszego brata — FINAŁ 
CARTRIDGE III. 

Nie jestem pewien, czy polski rynek został zdo¬ 
minowany przez karty MN AL dzięki ich zaletom czy 
też dzięki stosunkowo łatwemu kopiowaniu i po¬ 
wielaniu w zacisznych pieleszach domowych roż¬ 
nych elektroników amatorów Na dzień dzisiejszy 
jednak jest to jeden z najbardziej popularnych mo¬ 
dułów dla C-64. 

Karta ta zawiera w sobie dwie pamięci EPROM o 
pojemności 32 KB każda, dzięki czemu zwiększo¬ 
ne .ostały znacznie i możliwości. : estetyka progra¬ 
mów z rwanych w tym module FINAŁ CARTRIDGE 
Ml pracuje w oparciu o modną ostatnio lechnikę 
„okienek” Po włączeniu komputera na ekranie 
ukazuje się menu główne DESKTOP. won . 
głównego marny dostęp dc opcji iNF O j mewi o we- 
isji programu i jego autorach). SYSTEM (praca w 
BASIC^ wyłączenie programowa l 3 r * FREEZER 
oraz RbDRAW ponowne wyświetlenie wywoła¬ 
nych upizednio okienek), PROJECT (podręczny 
edytor tekstu). Dl!LITIES (konkguracja systcmu, 
kalkulator, zarządzanie zbiorami dyskowymi oraz 
TURBO ala DATASSETTt) i ClOĆK (ustawianie 
zegara i ewentualnie „alarmu na wyznaczoną go 
dzinęE Wvbor żądanej opcji polega na nałożeniu 
nań strzałki przesuwanej joystickiem iub klawisza 
mi funkcyjnym 1 i wciśnięciu przycisku Jak widać 
autorzy ćyif chyba mocno zafascynowani syste¬ 
mem GEÓS, czego reminiscencje widać nie tylko 
w menu głównym. 

Po wybran:u danej opcji na ekranie ukazuje się 
okienko zawierające szereg następnych do wybo¬ 
ru. Muszę przyznać, że wiele z nich fest naprawdę 
pożytecznych i przydatnych w codziennej pracy 
programisty: „beep" potwierdzający wciśnięcie 
klawisza, włączony blok nume?vczny (tylko jeśli dy¬ 
sponujesz C-128) powtarzanie klawiszy, deklara¬ 
cja standardowego urządzenia, z którymWspółpra¬ 
cujesz najczęściej. Jednorazowo można na ekranie 
wywołać kilka okienek, przy czym wywołane ostat¬ 
nio nakłada się na wyświetlane juz na ekranie. Po 
przesunięciu strzałki w górny lewy lub piawy róg 
możemy zamienić okienka (stare nałoży się na 
nowe); można je także przesuwać w dowolne miej¬ 
sce ekranu, wyłączać itp. Takie rozwiązanie znacz¬ 
nie ułatwia korzystanie z poszczególnych opcji kar¬ 
ty. 

Jedną z najczęściej wykorzystywanych możliwo¬ 
ści modułu jest program przyspieszający wczyty¬ 
wanie programów z dyskietki W porównaniu do 
wersji II został on znacznie ulepszony — wczyty¬ 
wanie odbywa się rzeczywiście w bardzo szybkim 
tempie Szkoda tylko, że opcja ta me jest dostępna 
stale — np po wczytaniu i uruchomieniu programu 
DISK DOCTOR procedura ta automatycznie się de- 
zaktywuje 

F NAL CARTRIDGE III zawiera również kilka op¬ 
cji dla miłośników programowania i grafiki kompute¬ 
rowej. W pierwszym wypadku użytkownik otrzymu¬ 
je do dyspozycji listę następujących poleceń dodat¬ 
kowych APPEND, ARRAY. AUTO, BAR ON/OFF, 
DEL, DESKTOP DLOAD DOS, DSAVE, DUMP, 
DVERiFY, FIND, HELP, KILL, MEM, MON, OLD, 
ORDER, PACK PD!R i PLiST, RENUM, TRACĘ, 
TYPE, UNPACK Z instrukcji tych można korzystać 
zarówno poprzez wpisanie jak tez i wybranie ich ze 
specjalnego menu wyświetlanego w pierwszej linii 
ekranu Sposób wyboru jest identyczny jak to opi¬ 
sano powyżej. 

Zreformowany w ten sposób BASIC jest rzeczy¬ 
wiście znaczme bardziej przyjemny aniżeli orygina¬ 
lna wersja V2.0 C 64 Bardzo przydają się tu prze¬ 
de wszystkim ARRAY (wyświetla na ekranie wszys- 
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tkie wykorzystywane w programie zmienne), FIND 
pozwalający na wyszukanie określonego ciągu tek¬ 
stu, czy MON wywołujący monitor języKa maszyno¬ 
wego o sporych możliwościach 

Podobnie jak w wersji ii, FINAŁ CARTRIDGE III 
wykorzystuje klawisze funkcyjne przypisując im 
konkretne instrukcje i rozkazy BASIC Niestety in¬ 
strukcje BASIC im przypisane są niezmienne ; me 
można ich zastąpić innymi; jest to jedna z waa tej 
karty 

Oprócz wspominanych powyżej karta ta oferuje 
ponadto cztery główne opcje: REEZER, NOTĘ 
PAD, PRINT oraz UTILITIES. Pierwsza z nich służy 
do nagłego zatrzymania wykonywania programu i 
zapisaniu całej zawartości pamięci RAM na dyskiet¬ 
ce lub taśmie; umożliwia to zarówno przenoszenie 
typowo dyskowych gier na taśmę (oczywiście me 
wszystkich!) jak tez i omijanie firmowych zabezpie¬ 
czeń — wystarczy, że program będzie wczytany z 
dyskietki (czy taśmy) oryginalnej. FREEZER ma kilka 
opcji dodatkowych pozwalających na zmianę kolo- 
row na ekranie graficznym, wyłączanie kolizji spri- 
te’ow, zmianę portów joysticka, włączenie progra¬ 
mowego AUTOFIRE itp. Wśród nich jest także op¬ 
cja PR NT umożliwiająca uzyskanie wydruku ekra¬ 
nu graficznego czy też tekstowego PrzyKładem 
mogą tu być rysunki do artykułu o programach ko¬ 
piujących wykonane właśnie za pomocą tej karty. 

Juz samo bliższe przyjrzenie się opcji PRINT 
może przyprawić o zawrót głowy. Pomijając już ta¬ 
kie „drobiazgi” jak możliwość powiększania rysun¬ 
ku w jednej z płaszczyzn (HORIZONTAL VERTI- 
CAL SIZE — maksymalne powiększenie jakie moż¬ 
na uzyskać jest dziewięciokrotne) czy wydruk od¬ 
wrócony o 90 stopni (SIDEWAYS), możliwe jest 
sterowanie wydrukiem drukarki 24-igłowej, wybór 
interfejsu (obsługa CENTRONICS jest zapisana w 
EPROM karty), wybór gęstości wydruku w trybie 
graficznym itp. Tu na marginesie pewna uwaaa 
posiadaczom drukarki NL-10 polecam wybór dru¬ 
karki EPSON, powiększenie rysunku w płaszczyź¬ 
nie poziomej (FłORIZONTAL SIZE=2) i wybranie 

OUBLE D iNSITY (podwójna gęstosć) z menu 
dla drukarek 8-igłowych. W takim układzie wydruk 
np. ekranu tekstowego przebiega w trybie graficz¬ 
nym, co daje znacznie lepszą czerń i kontury rysu¬ 
nku, Wybór ekranu graficznego lub tekstowego do 
wydruku oaoywa się automatycznie 

Stosunkowo najrzadziej wykorzystuję opcję 
NOTĘ PAD będącą małym edytorem tekstu Przy¬ 
pomina ona trochę NOTEPAD z systemu GEOS, 
ma jednak znacznie większe możliwości, m.in. po¬ 
zwala na regulowań e odstępu międzywierszowego 
i międzyznakowego (tylko na ekranie), pozwala na 
łączenie zbiorów dokumentów), wydruk itp Wyda¬ 
je mi się jednak, że jest to najsłabszy punkt karty i 
szkoda, ze miejsca zajmowanego przez ten edytor 
nie przeznaczono na zwiększenie możliwości opcji 
UTILITIES 

UTILITIES (programy użytkowe) oferują użytko¬ 
wnikowi możliwość wybrania i ustalenia najdogod¬ 
niejsze; konfiguracji systemu. Opcje DISK i 1 APE 

odnoszą się odpowiednio do zarządzania i zbiorami 
i programami na dyskietkach, jak tez wczytywania i 
zapisywania programów na kasetach w systemie 
normalnym (SLOW) lub TURBO (FAST). Oprócz 
wszystkich w zasadzie poleceń dyskowych (choc 
me moi ę przesłać z tego menu np. polecenia 
, U0 M1”) użytkownik może sortować alfabetycz¬ 
nie programy zapisane w katalogu dyskietki oraz 
wprowadzać lin e oddz elające pomiędzy ich tytuła¬ 
mi. Tym niemniej obsługa samego okienka jest nie¬ 
co bardziej skomplikowana, ponadto FINAŁ CAR¬ 
TRIDGE III nie dopuszcza możliwości wykonywa¬ 
nia operacji na więcej niż jednym zbiorze jedno¬ 
cześnie 

Moduł ten jest wyposażony w dwa przycisku 
FREEZER (lewa strona) oraz RESET Wciśnięcie 
RESET powoduje wyłączenie karty: jeżeli jednak 
będziemy przy tym trzymali wciśnięty klawisz RUN/ 
STOP to przejdziemy automatycznie do BASIC. Z 
kolei trzymanie wciśniętego klawisza COMMODO- 
RE LOGO (C=) spowoduje powrot do DESK OP 
Ta sama zasada obowiązuje w chwili włączania 
komputera do sieci. 

FREEZER może byc uaktywniany w dowolnej chwili 
(poprzez wciśnięcie lewego przycisku), należy jed¬ 
nak pamiętać, ze może on nie spełnić swojej funk¬ 
cji, jeśli „zamrażany program wykorzystuje przer¬ 
wania niemaskowalne NMI. TaKie potknięcie zda¬ 
rzyło się podczas prób wykonania wydruku z plan¬ 
szy tytułowej programu GEOS 

FIŃAL CARTRIDGE III ma jeszcze wiele innych 
zalet, które z braku miejsca przemilczę Generalnie 
jest to na pewno przydatna i znacznie lepsza karta 
aniżeli jej poprzednik; jest ona przede wszystkim 
dość uniwersalna, co pozwala mi polecic ją szero¬ 
kiemu gronu użytkowników, w tym także i począt- 

k Klaudiusz Dybowski 

UWAGA. FINAŁ CARTRIDGE III można kupić na 
warszawskiej giełdzie § oczywiście nie oryginał, 
lecz mniej lub bardziej udane kopie. Otrzyma¬ 
łem jednak kilka sygnałów od użytkowników, 
że me wszystkie egzemplarze zachowują się 
prawidłowo. Dlatego też przed zakupem propo¬ 
nowałbym sprawdzenie WSZYSTKICH dostęp¬ 
nych możliwości tej karty, gdyż w przeciwnym 
wypadku można kupie bubel za ok. 1GGGG0 zł. 
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Model ten należy do nowej 
generacji ręcznych kompute¬ 
rów personalnych. 

Generacja ta charakteryzuje się tym, ze w obudowie 
o wielkości kalkulatora {190mm x 97mm x 25mm) znaj¬ 
duje się prawdziwy komputer dający wyjątkowe możli- 
wisci obliczeniowe Te ręczne .komputerki" posiadają 
wbudowany język prgramewania wysokiego rzędu ja¬ 
kim najczęściej jest BASIC, choc spotyka się również 
PASCAL FORTH?. RP-71B posiada wbudowany BA¬ 
SIC, a dodatkowo można za pomocą specjalnego mo¬ 
dułu zainstalować FORTH i Assembier. 

Cechy użytkowe HP-71 

Tryb obliczeniowy CALC to potężny nieprogramowany 
tryb pracy łatwy do nauki i prosty w użyciu. Umożliwia 
przeprowadzenie najbardziej skomplikowanych obli¬ 
czeń. Wyrażenia wprowadzone są w formacie algebiai- 
cznym od lewej do prawej strony Dwanaście cyfr w 
wyniku zapewnia dokładność wszystkich obliczeń Po¬ 
nadto tryb CALC współpracuje z trybem programowa¬ 
nia BASIC. Polega to na tym, że wartości nadane 
zmiennym w BASIC mogą być wykorzystane (wywoła¬ 
nie przez nazwę zminnej) w trybie obliczeniowym i 
vice versa. Każde wyrażenie wpowadzone w BASIC 
może być obliczone w trybie CALC. W trybie CALC 
można posługiwać się wbudowanymi funkcjami nume¬ 
rycznymi, jak również własnymi procedurkami. Można 
go zadefiniować jako często używaną funkcję i następ¬ 
nie wywoływać ją po zaciśnięciu pojedynczego klawi¬ 
sza. Dodatkowe funkcje traktowane są na równi z wbu¬ 
dowanymi. Oczywiście HP-71 posiada wbudowaną 
statystykę umożliwiającą przeprowadzenie obliczeń na 
15 zmiennych niezależnych; pełny zestaw funkcji try 
gonometrycznych, logarytmicznych i innych. 

Tryb programowania BASIC to 240 funkcji, rozkazów, 
poleceń i operatorów upraszczających pisanie progra 
mów oraz czyniącym je przyjemniejszym. Program 
główny może składać się z szeregu podprogramów z 
którymi może wymieniać się parametrami (parametry 
formalne i aktualne). Z ciekawszych poleceń wymienić 
trzeba instrukcje PRiVATE ograniczającą osobom nie¬ 
powołanym dostęp do zbiorow jak również zabezpie¬ 
czającą zbiór przed wprowadzeń em poprawek, zm an 
SECURE (UNSECURE zabezpieczają) odbezp eczają 
zbiór, program przed skasowaniem; CHAIN kopiuje 
zbiór do głównej pamięci RAM i automatycznie wyko¬ 
nuje polecenia zawarte o tym zbiorze: BEEP wzboga¬ 
cający programy o przerywnik akustyczne o regulowa¬ 
nej długości i częstotliwości (zakres SH2 — 6200Hz). 

Ostatnim 1 czasy kalkulatory i takie podręczne kom¬ 
puterki coraz częściej wyposażone są przez producen¬ 
tów w systemy operacyjne większe niż te zainstalowa¬ 
ne na niejednym prawdziwym komputerze HP-71 po¬ 
siada 64 KB system operacyjny umożliwiający prze¬ 
prowadzenie najbardziej wyrafinowanych i wymyślnych 
działań System operacyjny zawsze czuwa! HP-71 po¬ 
siada pięciopoziomowy stos (rozszerzalny do 16 po- 
ziomow) zapamiętujący ostatnio wyKonane działania, 
rozkazy i dający możliwiść ich powtórzenia bez powtó¬ 
rnego opisywania ciągu rozkazów Znakomicie przy¬ 
spiesza to przeprowadzenie długich, żmudnych obli¬ 
czeń dla których jednak z tego czy innego powodu nie 
warto pisać programu HP-71 wyposażony jest w czte¬ 
ry pa r y RAM'ROM Standardowa pamięć RAM wynosi 
17 5 KB, którą można rozszerzyć o 16 KB do łącznych 
33* 5KB. Aby umożliwić przyszłe rozbudowanie syste¬ 
mu HP-71 jest zaprojektowany tak aby dać możliwość 
bezpośredniego adresowania 512 KB pamięci. W celu 
zaoszczędzenia czasu przy programowaniu, można się 
posłużyć gotowymi modułami ROM z programami (256 
KB) Programy te są opracowywane przez firmę, która 
dysponuje olbrzymią biblioteką programów do wszyst¬ 
kich wypuszczonych kalkulatorów (komputerów). Moz 
na również bezpośrednio u Hewletl-PackorcTa zamó¬ 
wić przeniesienie naszych programów na taki gotowy 
cartridge Dowolny obszar wbudowanej i zewnętrznej 
RAM może zestaw wydzieiony dla programu s do prze¬ 
chowywania danych, tak aby zbiory były łatwo dostęp¬ 
ne i zabezpieczone przed skasowaniem podczas rese- 
tu komputera. Można również odłączyć moduły pamię¬ 
ci RAM bez uszkodzenia zbiorów w pozostałej części 
pamięci RAM 


Często używane słowa kluczowe znajdują się na kia- 
wiat;ze i mogą być wyświetlone przy naciśnięciu poje¬ 
dynczego klawisza (tak jak w spectrum) Komputer ten 
me posiada jeszcze menu (jak HP-28, HP-27 HP 
32)diatego każdemu klawiszowi (55 klaund przypisane 
jest do trzech funkcji wybieranych klawiszami: żółtym f 
i niebieskim g). Klawiatura jest w pełni redefiniowana 
tzn. że każdemu klawiszowi można przydzielić inną 
funkcję niż ta standardowo do mego przydzielona. Ta¬ 
kie możliwości w połączeniu ze specjalnymi nakładka¬ 
mi na klawiaturę umożliwiają wygodne wykonanie pro¬ 
gramów bez konieczności uczenia się kiawiszowania 
do danego zastosowania. 

HP-71 posiada obudowany zegar (o regulowanej 
prędkości działania 10) w kalendarz Oprócz ich dużej 
dokładności działania, również przy wyłączonym kom¬ 
puterze, mogą być one wykorzystane p r zy programo¬ 
waniu i uruchamianiu programów jako np. zmienne de¬ 
cyzyjne 

Liczba rożnych zbiorów jakie mogą być w pamięci 
komputera ograniczona jest jedynie dostępną pamięcią 
RAM. Można się posłużyć 7 różnymi typami zbiorów. 

BASIC — zbiory zawierają teksty programów w BA- 
SiC-u 

BIN — programy w języku maszynowym do wyko¬ 
rzystania jako program lub podprogram 

LEX — zbiory przechowujące niezdefiniowane pole¬ 
cenia BASIC 

DATA — zbiory przechowujące dane numeryczne i 
tekstowe 

Text — zbiory służące do przekazywania danych do/ 
z innych komputerów 

KEY — zbiory określające aktualną definicję klawiszy 

na klawiaturze 

DATA — zbiory umożliwiające przekazywanie zbio¬ 
row do/z kalkulatora serii HP-41 (wkrótce w klanie użyt¬ 
kowników kalkulatorów) 

Z ogólnych danych technicznych podaję za produ¬ 
centem parametry tej miniaturki komputera Waga 
340g wraz z czterema bateriami typu AAA Wyświet¬ 
lacz 256 różnych znaków wyświetlanych jest w oparciu 
o matrycę 6x8 punktów Na wyświetlaczu mieszczą 
s ę 22 znaki ze scrollmgiem w Imi do 96 znaków 
Zakres numeryczny 

rzeczywista precyzja — 9,99999999999 E99 —1E- 
499; 0 1E 499 9.99999999999 E 499 
Krotka precyzja: jw. lecz z dokładnością do 4 miejsc po 
przecinku (lub kropce dzies ętnej do wyboru) 
liczby całkowite —99999 —99999 
Wszystkich możliwości tak wyrafinowanego komputera 
me da s ę zawrzeć w tak krótkim artykule Wspomnę 
jeszcze o paru cechach wyróżniających HP-71 na tle 
podobnych komputerów Czytnik pasków magnetycz¬ 
nych o pojemności 1,3 kB daje możliwość stworzenia 
biblioteki oprogramowania, przechowywania danych, 
tekstów i innych informacji na taśmę nośnika bez ko¬ 
nieczności każdorazowego „wpakowywania’ ich do 
pamięci. Czytnik napędzany jest ręcznie więc zaosz¬ 
czędza nam baterii. 

Tak jak w komputerach, tak HP-71 posiadł otwartą ar¬ 
chitekturę Oznacza to, ze można go dostosowywać do 
rożnych często specyficznych zastowowan Za pomo¬ 
cą interfejsu HP-IL można HP-71 podłączyć do urzą¬ 
dzeń peryferyjnych, instrumentów pomiarowych wypo¬ 
sażonych w złącza RS-232C, HP-IB (IEEE 488), GPIO 
Za pomocą HP-IL, HP-71 może jednocześnie komuni¬ 
kować się z 30 urządzeniami połączonymi w pętli Przy 
dodatkowym adresowaniu wspomagającym liczba ta 
rośnie do 930 urządzeń choć osobiście me wyobrażam 
sobie takiego zastosowania 

Z urządzeń peryferyjnych wymienić trzeba monitor 80- 
kolumnowy do HP-71; plotter, drukarkę, stieemer; sta 
cję dysków, magnetofon cyfrowy, modem i wiele in¬ 
nych Reasumując trzeba stwierdzić, że HP-71 jest od¬ 
powiednim urządzeniem do zastosowań, do których 
komputer jest jeszcze za drogi. Dzięki olbrzymim mo¬ 
żliwościom i małym gabarytom spełnia funkcje dobrze 
oprogramowanego komputera z własnym zas laniem 
dającego rnoziiwosc korzystania z niego wszędzie w 
podróży, na warsztacie — podłączenia do instrumen¬ 
tów pomiarowych celem pobrania danych do dalszej 
obróbki itd. 

Dominik Falkowski 
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Królestwem, którym jeszcze niedawno rżąc ziłeś, zaw¬ 
ładnął podstępny Czarnoksiężnik w postaci olbrzymiej, 
szkaradnej bestii. Wsączył w serca Twoich byłych pod¬ 
danych strach i potworną grozę. Twoje wojska w nieró¬ 
wnej walce zostały doszczętnie rozgromione Po tej po¬ 
rażce mulisz sam postarać się unieszkodliwić tyrana. Z 
pewnych źródeł wiesz, że słabą stroną bestii jest jego, 
ntechroniona skorupą głowa. Wiedz lał on, że przybę- 
dziesz odebrać swoją utraconą koronę. Rozmieścił po 
całym zamku demoniczną straż. Swoje magiczne przed¬ 
mioty dla pewności powierzył sługom w różnych częś¬ 
ciach dużej budowli. Musisz je zdobyć i przy ich pomocy 
odzyskać władzę. Jeśli ci się nie uda Twoja misja, całe 
państwo pogrąży się w otchłaniach ciemności t magii 
potwora. Aby dostać się do niektórych części kamienne¬ 
go kolosa, będziesz musiał zmienić swoją postać. Czeka 
cię trudne zadanie. 


Sebastian Kajdan 
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Kopertę nadesłał Łukasz Wielgosz z Wrześni 




Dialektyka — jedność przeciwieństw jest budulcem lego 
świata. Również i Listy Przebojów Gry nowe i stare, 
wściekłe strzelaniny i łagodne tekstówki spotykają się w 
pierwszej dziesiątce ulubionych gier. Tak jest i w tym rnie 
siącu. Króluje „Operation Wolf", obecna u nas stosunko¬ 
wo od niedawna Dalej również gry me najstarsze pewne 
zaciekawienie budzi „Police Ouest 5 i „Kmg’3 Quest' : do¬ 
stępne na niewiele komputerów A na samym końcu „Gre- 
en Beret 5 ’, historia i klasyka obłędnych zręcznościówek 
Na siódme tegoroczne notowanie Listy napłynęło 3590 
propozycji na 194 tytuły gier. 
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Jest rok 1940. Niemieckie fabryki pracu¬ 
ją na pełnych obrotach, aby dostarczyć wojsku 
potrzebny sprzęt i amunicję. Messerschmitty ty¬ 
siącami wędrują na front wielkie opancerzone 
czołgi stoją na platformach, czekając na rozkaz. 
Podkute buty narodowego socjalizmu szykują 
się do podbicia wielkich obszarów Francji i Ros¬ 
ji, niedługo zjawią się też w Jugosławii i H szpa- 
nii. Nie ma takiego państwa ani systemu, który 
zdoła zatrzymać tę szerzącą się w oszołamiają- 
cym tempie plagę Jest natomiast człowiek, mo¬ 
gący całą niemiecką machinę zmienić w bez¬ 
władną bryłę śmiecia 

Pewnej nocy, gcty siedziałeś przy biurku rysu¬ 
jąc model maszyny parowej, pokój zaczął nagle 

drgać i wibrować Na stole ukazały się schematy 
bardzo dziwnego urządzenia, wyglądającego z 
pozoru jak pojemnik na jedzenie. Jednak, gdy 
zmontowano go w jednym z laboratoriów, w 
woim ręku znalazł się supernowoczesny ple¬ 
cak rakietowy, z turbo odrzutem powierzchnio¬ 
wym oraz scalacją przestrzeni i czasu Właśnie 
przy jego pomocy masz szansę walczyc ze znie¬ 
nawidzonym faszyzmem oraz z Wehrmachtem, 
Luftwaffe i Kriegsmari- 
ne Ostateczne zwy 
cięstwo jest w zasięgu 
graczy o silnym cha¬ 
rakterze, którzy spę¬ 
dzą przy komputerze 
min mum miesiąc 

Gdy zaczynasz, mo¬ 
żesz wykonać jedną z 
czterech czynności- 
WAR MAP — mapa 
świata Oznaczone są 
na niej państwa odgry¬ 
wające jeszcze jakąś 
rolę w wojnie. Posia¬ 
dasz pięciu agentów, 
których mozesz dowo¬ 
lnie przemieszczać 
Sa om jednak bardzo 
narażeni na zdemas¬ 
kowanie, co zawsze 
kończy się dla nich 
śmiercią, lub obozem 
koncentracyjnym 
Każdy z wywiadowców 
może organizować 
ruch oporu, masz tak¬ 
że możliwość zwięk¬ 
szania szybkości i 
efektywności ich dzia¬ 
łania 

FUEL DEPOT — ma¬ 
gazyn paliwa Zaopa¬ 
trujesz się tutaj w pali¬ 
wo do swojego pleca¬ 
ka oraz rakiety. Pamię¬ 
taj, ze me całe paliwo 


zużyjesz na raz, część zostaw na powrót lub lot 
do innego kraju. 

ROCKET LAB — informacje o ilości zdobytych 
części od nowej niemieckiej rakiety 
TAKE OFF — start Przewożony zostajesz do 
Fort Dix, gdzie startujesz (lub nie) z betonowe 
go pasa. W tym celu na Każde dotknięcie nogą 
ziemi, przyciśnij FIRE + lewo Gdy odezwie się 
sygnał dźwiękowy informujący o możliwości 
oderwania się od powierzchni ziemi, wciśnij FI¬ 
RE t góra Odległość lotu dete r mmuje ilość za¬ 
ładowanego wcześniej paliwa do zbiornika w 
plecaku Zależności te znajdują się w załączonej 
taoelce 

Informacje przekazywane przez wywiadów 
ców mówią zwykle o odk r yciu tajnej bazy. Lot 
do mej jest konieczny, gdyż właśnie tam masz 
możliwość zdobycia jednej z pięciu części ra¬ 
kiety, którą Niemcy chcą użyć do lotów na Księ¬ 
życ. Inne wiadomości przekazywane przez 
agentów dotyczą transportów wojskowych, wy¬ 
krytych fabryk itp 

Na samym początku gry, niemieccy koman¬ 
dosi nadlatują sterowcem nad Nowy Jork i pory- 
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wają jednego z najlepszych amerykańskich nau¬ 
kowców — Ottona Barnstorffa. wraz z córką 
Jane. Jedynym sposobem na ich uratowanie 
jest odnalezienie sterowca w trakcie powrotu do 
Nsemiec i zajęcie go. Pamięta' jednak, ze trafie¬ 
nie w powłokę wypełnioną wodorem powoduje 
w elki wybuch, z ktorego nie uratuje się nikt, 
oprocz Ciebie 

Gdy uda Ci się dostać ao wnętrza sterowca, 
zadanie Twoje me będzie jeszcze zaKonczone. 
Odpowiednimi słowami powinieneś przekonać 


Jane, ze jestes przyjacielem. Jeżeli me uwierzy, 
poleci wraz z ojcem prosto do Niemiec, aby już 
nigdy me ujrzeć świateł Nowego Jorku. 

Tak więc los Europy i Świata spoczywa w 
’ woich rękach. Czy na Białym Domu zawiśnie 
rlaga ze swastyką, czy tez staniesz ssę bohate¬ 
rem o którym me zapomną pokolenia? 

Firmę: Strike Force 

Komputer: ZX Spectrum 48/ a , Commodore 
64, Atari ST 

Lukę 


Pływaliśmy juz rożnymi urządzeniami, 
raz na wodzie, raz pod wodą Lataliśmy szybko i 
wolno, wysoko i nisko, a'e nigdy jeszcze me po¬ 
ruszaliśmy się wodolotem 

PHM Pegasus to nazwa eksperymentalnego 
wodolotu, Który używany będzie przeciwko pira¬ 
tom. Jedyne dwa istniejące egzemplarze Pega- 
susa ma w posiadaniu armia UK i skrzętnie ich 
pilnuje. Jak więc ten dostał ssę w Twoje ręce? 
Zamieszana jest w to firma EOA, ale lepiej o to 
me pytać, adyz może byc to ostatnie zadane py¬ 
tanie. 

Tak więc masz ten wodolot i me wiesz, jak się 
mm posługiwać? Nic prostszego, mogę przybli¬ 
żyć Ci tę trudną sztukę, lecz mniemam, iz Twa 
wdzięczność wyrazi się w miarodajnych jednos¬ 
tkach... 

Na początku popatrz dobrze na mapę, roz¬ 
wieszoną w kabinie Widzisz tam pewną częsc 
morza, kawał lądu i kilka małych punktów. Ten, 
obwiedziony jasnym okręgiem, to Pegasus, a 
okrąg pokazuje zasięg jego radaru, a więc i 
strzałów inne kropk* to jednostki pływające lub 
latające; obwiedzione okręgami będą Ci przyja¬ 
zne. 

Klawiszami FI — F4 rnozesz przełączać na¬ 
dajnik wy n,. ;zac kurs d«a każdej jednostki. 
Kurs pr■_osuwasz joystickiem, zas prędkość 
; eg u; wesz Klawiszami 1—5 

Czy czas me płynie zbyt wolno? Jeśli tak, to 
używając Klawiszy a i - możesz jego upływ od- 
p o w i e d n i o z w i e i o k r o t n i c. 

Wciśnij V — znajdziesz się przy oknie Spacją 
zmieniasz tiyb z ma ewrowan.a na strzelanie i 
odwrotnie. W i»yble manewrowania porusza me 
joystickiem powoduje odę owieonie przyspie¬ 


szanie i zwalnianie oraz skręt w lewo lub prawo 
Trybu strzelania używaj gdy uchwycisz cel w 
lornetkę 

Zasięg radaru zmieniasz klawiszem R Kla¬ 
wisz T powoduje uchwycenie najbliższego celu 
w lornetkę oraz zmianę celu Wtedy rnozesz 
włączyć tryb strzelania, wybrać rodzaj brom kla¬ 
wiszem W (gun — działo, chaff — flary, hasm — 
rakiety samonaprowadzające średniego zasię¬ 
gu, gabnel — rakiety samonaprowadzające da¬ 
lekiego zasięgu), joystickiem przemieścić kur¬ 
sor w lornetce i strzelać. 

W czasie pogoni za uciekającymi celami me 
zbliz się za bardzo do brzegu O krytycznej głę¬ 
bokości (płytkości) wody poinformuje wskaźnik 
DEPTH na tablicy przyrządów 
To już wszystko, co potrafi Twój Peaasus Nie 
jest to wcale mało, przekonasz się o tym w akcji 
Którą zas z nich wybierzesz, to zalezy od Cie¬ 
bie Każda jest inna i rożny jest tez ich stopień 
trudności. Tak więc baw się dobrze i nie popsuj 
wodoiotu, lecz odstaw go na miejsce nietknięty. 
Firma: Electronic Arts 
Producent: Lucasfiim Games 
Komputer: ZX Spectrum 48/+, Commodore 
64, Atari ST, IBM PC. 

Gen 


Proszę o udzielenie mi informacji o grze UN!VERSAL 
HERO. Nie wiem, co zrobić w komnacie z Komputerem po 
pojawieniu się napisu , Piease identify your self” 

Łukasz Mazurkiewicz uL Zamieniecka 17 04—158 

Warszawa 

Posiadam mikrokomputer C—16. Chciałbym rozszerzyć 
pamięć do 64 Kb Bardzo proszę o podanie adresu insty¬ 
tucji lub osoby prywatnej mogącej dokonać tej przeróbki 
(Okolice Śląska) 

Dariusz Bieniek ui. Karola Miarki 21/3 
41—500 Chorzow 

Próbuję rozszyfrować grę ROBIN HOOD. Chodzę po lesie 
i w pewnym miejscu Robin zatrzymuje się. Co potem ro¬ 
bie? W zamian za pomoc oteruję 150 gier i opssow Poszu¬ 
kuję także gry BARBARIAN, CONAN ZORRO II, ZYBEX 
Posiadam Atari i 80QXL 

Dane Krajewski ul. Wańkowicza 9b/10 
58—500 Jelenia Góra 
Commodorowcy pomóżcie! Nie mogę uruchomię gry BO- 
ULDER DASH w wersji na C-16. 

Psotr Czesak ul Klonowa 20/19 00—901 Warszawa 
Pilnie potrzebuję na mikrokomputer Spectrum gier KUNC- 
FU MASTER, POP EYE, GUN FRIGHT. Wymienię je na 
inne 

Ryszard Opara ul. Zemska 36/17 54—438 Nowy Dwór 

woj wrocławski 

Gry SPY vs SPY IJUli, STAROUAKE THE GOONIES, 
PAN HER i wiele innych zamienię na BARBARIAN, S^Y 
vs SPY IV, HOBBIT, WINTER GAMES i MISS PACMAN 
Posiadam Atarii 65XE 

Piotr Pańczyk ul. H, Sawickiej 17/25 43—100 Tychy 

Jestem posiadaczem Commodore +4. Do czego służy in¬ 
strukcja SPRAY w programie SPEECH PLUS. Jak grac w 
MAYHEM, BEACH rIEAD. BATTLE i MISSON APOLLO. 

W zamian służę opisami wieiu gier. 

Marcin Sokołowski ul. Urzędnicza 9a/44 

25—729 Kielce 

Proszę o pomoc w zdobyciu gry BARBARIAN w wersji ka¬ 
setowej na Atari 65XE. 

Adam Maik os. Zwycięstwa 11/46 61—646 Poznan 

W zamian za opisy du gier PYJAMARAMA, CONOULST 
UNIYERSAL HERO MONTEZUMAs PFVENGE oferuję 
mapy gier PHARAONś CURSE, STAROUAKE, JET SET 
WILLY, PiTFALL II, BRUCE LEE. Mam Timexa 2048 Po 
mozcie 1 

Tomasz Szułczynski os. Świerczewskiego 41/8 64/300 

Nowy Tomyśl 

Proszę o informację, jak przejść trzecią i drugą planszę w 
grze THE GOONIES w wersji na Spectrum 

Paweł Parys ul. Goławicka 4/8 03/550 Warszawa 

Posiadam Atari 65XE Proszę o pomoc w grach SILENT 
SERViCE< HARD BALL, EASTERN FRONT, Dizzy DiCE i 
FIN ORBIT W zamian służę pięćdziesięcioma opisami do 

gier. 

Piotr Adamiak, ul. M Konopnickiej 8h/2, 63-400 

Ostrów Wikp. woj. kaliskie 


Hanna Pus lat 18, uczennica klasy III ^uio 
logiczno-chemicznej) VIII LO im Adama 
Mickiewicza w Poznaniu. 

Jeszcze me ma komputera, ale chciałaby 
mtec Commodore 64 
Lubi wszystkie gry komputerowe 
Hobby Muzyka rozrywkowa 


Marcin Pruszynski lat 17, uczeń klasy II t 
Technikum Energetycznego w Warszawie 
Posiadany komputer Commodore 64 
Ulubiona gra Tetr s. 

Hobby muzyka, informatyka żeglarstwo 
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NASTĘPNY KROK 


Oto zadanie godne mistrzów 
klawiatury: mamy zapisany 
ciąg liczb. Dostając jakąś nową 
liczbę musimy szybko spraw¬ 
dzić czy jest ona w tym ciągu. 
Zadanie takie wynika przy wie¬ 
lu zastosowaniach praktycz¬ 
nych, dodatkowo utrudnione 
przez to, źe nasz ciąg może być 
modyfikowany w czasie pracy 
— można do niego dopisać 
oraz usuwać z niego elementy. 


W ub egłym miesiącu stwierdziliśmy, ze wyszukiwa¬ 
nie jest dużo szybsze jeśli nasz ciąg (zapisany w tabli¬ 
cy jednowymiarowej) posortujemy przed rozpoczę¬ 
ciem poszukiwań Wtedy jednak musimy uważać przy 
wstawianiu zęby zachować porządek Wymyśliliśmy 
dwa sposoby poradzenia sob e — dostawie nowy ele¬ 
ment na końcu i ponownie wywołać sortowanie, lub 
elementy w ększe od wstawianego przesuną — w pra¬ 
wo o jedną pozycję, tak aby od razu można wstawać 
na właściwe miejsce 

Pierwsza metoda jest kosztowna (przyjęliśmy, że 
koszt prymitywnego algorytmu sortowania wynosi N ), 
koszt drugiej wynosi ok N operacji. Tak więc wstawia¬ 
jąc pojedynczy element nie możemy się wahać ant 
chwili którą wybrać Ale jeśl mamy do wstawienia np 
10 czy 20 nowych pozycji od razu, czy me taniej bę¬ 
dzie dopisać wszystkie a następnie raz posortować ca 
łosc? Intuicyjnie pomysł wydaje się niegłupi, ale dla 
pewności warto by przeliczyć Zrobimy to w sposob 
uproszczony, zakładając, że N jest bardzo dużą liczbą i 
dlatego zwiększanie jego wartości podczas dodawania 
kilkunastu elementów można pominąć (zamiast N + 10 
w rachunkach użyjemy N) Jedno posortowanie będzie 
nas kosztowało zaś dodan e 10 liczb przez przesu¬ 
wanie wartości w tablicy będzie kosztowało 

10 N czyli dla dużych wartość N znaczn e mn ej n z 
jedno jedyne posortowanie Np dla N = 1000 mamy 
N = 1000000, a 10 N# 10000, czyi różnica ogromna, i 
co należy podkreślić zupełme sprzeczna z naszym po¬ 
przednimi intuicjami Jednak wymowa cyfr jest jednoz¬ 
naczna i wniosek ostateczny chyba tez — me wolno 
nam zbytnio polegać na intuicji, tam gdzie chcemy 
ocemac efektywność działania algorytmów niezbędne 
są precyzyjne rachunki Dla porządku wreszcie dodaj¬ 
my, ze przyjmując do rozwazan inny koszt algorytmu 
sortowanie N liczb (możliwe jest NIogN), nny przedział 
wartości danej N oraz inną losc jednorazowo dosta¬ 
wianych elementów (np zbliżoną do wartości N) mo¬ 
żemy otrzymać inną ocenę opłacalności 

Tyle zaległych rozrachunków ze wstawianym Po¬ 
myślmy o drugim problemie — usuwaniu elementów 
Tu znowu są przynajmniej dwie możliwości albo od 
razu fizycznie usuwamy wartość, tzn przesuwamy ele¬ 
menty lezące na prawo od usuwanego o jedno miejsce 
w lewo, także zostaje on zamazany, — albo w miejscu 
usuwanej wartość wpisujemy jakąś liczbę o której 
wiemy, ze na pewno me może wystąpić w naszym cią¬ 
gu i liczba ta (w niektórych zastosowaniach może to 
być po prostu zero) będzie oznaczać „to miejsce jest 
puste” 

WESTCHNIENIE ZA PROSTOTĄ 

Pierwsza metoda jest dosc prosta koncepcyjnie, ale 
za to pracochłonna w realizacji — wymaga wielu prze¬ 
sunięć Druga pozwala zaoszczędzić tych przesunięć 
ale stwarza nowe problemy: wstawiane „puste ele¬ 
menty” mogą zaburzać porządek tablicy, więc trzeba 
je odrębnie traktować przy przeszukiwaniu, blokują 
one miejsce w tablicy, więc trzeba od czasu do czasu 
wykonać odsmiecan e i przesunąć zawartość tablicy w 
lewo likwidując wszystkie nagromadzone „pustosta¬ 
ny za jednym zamachem Można tez inaczej, dopisu¬ 
jąc nowy element szukać miejsca po usuniętym a do¬ 
piero gdy tak ego me będzie dopisywać na końcu. Mo¬ 
żna to wszystko jeszcze bardziej rozbudowywać (i 
oczywiście komplikować), wzdychając tylko do czasu 
do czasu: „takie to było piękne, proste zadanie..." 

Niestety wszystkie omowione problemy muszą zna¬ 
le/ć rozwiązanie, więc nie uda nam się odzyskać pro¬ 
stoty przez ich zignorowanie Ciągłe przesuwania ele¬ 
mentów tablicy tez me mogą nas satysfakcjonować — 
zami: t odpowiadać czy szukane elementy są w na¬ 
szym ( ciu będziemy w kołko reorganizować zawar¬ 
tość 


Powie* my jeszcze na chwilę do przykładu, w którym 
dany cisu byt listą identyfikatorów towarow znajdują¬ 
cych się w magazynie Zwykle o każdym towarze mu¬ 
simy zapam ętac sporo danych ilosc sztuk, data, do¬ 
stawy, cena itd Wtedy me mamy do czynienia z jedno¬ 
wymiarową tablicą numerów towaru, lecz z tablicą mie- 
jącą tyle kolumn ile danych mamy w towarze 
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Numer 

Ilosc 

Data dostawy 

Nr regału 

Nr półki 

5 

11 

34 

43 

223 

241 






Jeden wiersz tablicy stanowi opis jednej pozycji, zaś 
numery pozycji mieszczą się w pierwszej kolumnie 
tzn nasze poszukiwania wykonujemy w pierwszej ko¬ 
lumnie Ale przesuwając musimy zawsze przesuwać 
me pojedyncze liczby lecz całe wiersze zęby mepogu- 
bic informacji. Teraz dopiero są powody do wzdycha¬ 
nia 


WŁODEK, ZACZYNAMY 
OD NOWA 

Musimy znaleźć inne rozwiązanie a kierunek poszu¬ 
kiwań wydaje się być zupełnie jednoznaczny — wszy¬ 
stkie nasze kłopoty wzięły się z szukania nowego i 
odzyskiwania zwolnionego miejsca w tablicy Tablica 
okazała się strasznie sztywną strukturą za sztywną jak 
na potrzeby tego zadania Musimy cofnąc się az do 
pierwszego kroku, którym był wybór sposobu repre¬ 
zentacji danych w pamięci i zapisać dane w inny spo¬ 
sob. 

Zęby znowu ominąć szczegóły ustalamy, ze wszyst¬ 
kie informacje o jednej części tworzą jeden zapis (czę¬ 
sto mówmy „rekord’ od angielskiego record) Struk¬ 
tury tego rekordu me będziemy badać, bo może byc 
rożna w rożnych zadaniach Ważne jest, ze w rekor¬ 
dzie występuje pozycja pozwalająca go jednoznacznie 
zidentyfikować Tak wnęc mając ciąg rekordów może¬ 
my wziąć pod uwagę identyfikator każdego z nich i... 
mamy nasze poprzedn e zadanie wyszukiwania — w 
ciągu liczb (identyfikatorów rekordów) odszukać poda¬ 
ną na wejście wartość X (i w ten sposob równocześnie 
odszukujemy rekord o identyfiaKatorze X), w naryso¬ 
wanej poprzednio tabelce jednym rekordem jest jeden 
wiersz, a identyf katorem rekordu jest numer zapisany 
w pierszej kolumnie 

Jednak z reprezentacji w postaci tablicy postanowi¬ 
liśmy zrezygnować, w związku z tym spróbujemy ciąg 
naszych reKordow zapisać w sposob, który graficznie 
można przedstawić następująco 



Na razie me wnikajmy w istotę strzałek łączących re¬ 
kordy, chcemy tylko by jednoznacznie określały poło¬ 
żenie następnego rekordu w pamięci i pozwalały do 
mego łatwo przejść Popatrzmy jakie możliwości uzys¬ 
kamy i jes! nas zadowolą to zajmiemy s*ę techniczną 
stroną realizacji 





~~i- 



a następnie przeglądamy listę juz wpisanych rekordów 
porównując wartości identyfikatorów z wartością nowo 
wpisywanego aby ustalić między którymi rekordami 
trzeba wstawić nowy Gdy juz je zna idziemy po prostu 
przestawiamy strzałk tak aby nowy rekord wszedł na 
własowe miejsce 



Dzięki naszym strzałkom operacja odbyła s ę pomy¬ 
ślnie bez konieczności przepisywania jakiegokolwiek 
rekordu z miejsca na miejsce A co z usuwaniem'? Od¬ 
będzie się leszcze prościej wystarczy tylko przesunąć 
jedną strzałkę Z ciągu 


(D 


111 


W 



34 | 

i 

43 | 

.. ! 


V 



chcemy usunąć element o identyfikatorze 11 (czasem 
zamiast identyfikator mówimy kiucz, co jest odpowied¬ 
nikiem angielskiego terminu key). Trzeba znaiezc wła¬ 
ściwy rekord, a następnie ustawić strzałki jak następu 

je: 



A jak szukać danych przy tej metodzie zapisu 1 ? Bie¬ 
rzemy pierwszy rekord, sprawdzamy wartość klucza, 
jeśli jest mówimy to znaleźliśmy, jeśli me to posługując 
się wartością strzałki przechodzimy do następnego, 
sprawdzamy wartość klucza itd Aby opisana operacja 
mogła się zakończyć gdy elementu nie ma musimy 
mieć możliwość stwierdzenia ze doszliśmy do końca 
Musimy urn ec nadać naszej strzałce pustą wartość, 
oznaczającą „nie pokazuje na żaden rekord ? Napot¬ 
kanie takiej wartości będzie oczywiście oznaczać ko¬ 
niec listy Na naszych rysunkach wartością taką jest 



USUWANIE JEDNYM RUCHEM 


Spróbujmy zrealizować to co stwarzało nam najwięk- 
sze problemy dopisywanie i usuwanie elementów 
uporządkowanego ciągu 

Aby dodać nowy rekord musimy zapisać w pamięci 
jego treść, przy czym możemy to zrobić w dowolnym 
miejscu 


Opisana powyżej (na razie tylko rysunkami) struktura 
danych to lista Nie jest ona oczywiście mcirn wynala¬ 
zkiem, słyszał o niej każdy oob r ze wyszkolony inior 
matyk. Listy są bardzo pożyteczne m.ędzy innymi w 
sytuacji takiej jak nasza, gdy elementy na których pra¬ 
cujemy pcjawiaią się i znikają dynamicznie — w czasie 
pracy 

jak samo narysowanie schematu listy nie wyczerpu¬ 
je tematu. Musimy porozmawiać o jej realizacji w prak¬ 
tyce oraz o problemie gospodarowania wolnym miejs¬ 
cem, ale to wszystko dopiero w następnym numerze, 

Andrzej Krul 
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JĘZYK 



DLA NAJMŁODSZYCH 

czyli 

kolejny wieczór 
z czamokię nikiem 



W poprzednim odcinku 
poznaliśmy miłego czarno¬ 
księżnika, który znalazł 
przypadkowo na strychu 
komputer i podręcznik z 
czarodziejskimi zaklęciami 
w języku „C”. Podczas 
pierwszego wieczoru nau¬ 
czył Ssę on wprowadzać do 
komputera i wyświetlać na 
ekranie monitora informacje 
tekstowe. 

Następnego wieczora Czarnok¬ 
siężnik ponownie usiaai przy swoim 
komputerze. Tym razem postanowił 
nauczye się wprowadzać i wyświet¬ 
lać liczby 

W języku ;i C liczby dzielimy na 
dwa rodzaie: 

— całkowite — to te, przy po¬ 

mocy których 
liczymy samo¬ 
chody, ludzi 
lub krzesła 
(także te poży¬ 
czone) 

— rzeczywiste — to te, przy 

pomocy któ¬ 
rych mierzy¬ 
my odległoś¬ 
ci między 
dwoma pun¬ 
ktami lub 
wyrażamy 
wagę jakie¬ 
goś przed¬ 
miotu. 

Każda liczba zajmuje pewien ob¬ 
szar pamięci komputera Rozmiar 
obszaru zajętego orze z dana liczbę 
jest inny dla Każdego rodzaju liczb i 
jest związany z wielkością (zakre¬ 
sem) liczb możliwych do zapamię¬ 
tania. Jeśli zakres ten jest mały w 
stosunku do naszych potrzeb, wte¬ 
dy możemy ao rozszerzyć zmienia¬ 
jąc rodzaj „całkowita na „długa’ 
lub „rzeczywista” na „precyzyjna” 
Są jeszcze inne możliwości, na po¬ 
czątek jednak te informacje nam 
wystarczą. 


Nasz znajomy czarnoksiężnik 

oglądał niedawno film o piratach 
Bohaterowie tego filmu pływali po 
morzach i często mówili, ze prze¬ 
płynęli ileś mil morskich My jednak 
przyzwyczajeni jesteśmy do kilo¬ 
metrów Czarnoksiężnik postanowił 
napisać program, który będzie 
przeliczał mile na kilometry 

Należało w tym celu odwołać się 
do treści książki Było w niej napisa¬ 
ne- 

„Każda liczba, która będzie 
wczytana do komputera lub obli¬ 
czona przez program musi byc za¬ 
pamiętana w miejscu pamięci zwa¬ 
nym zmienną Nazwy wszystkich 
występujących w programie oraz 
ich rodzaj muszą byc wyszczegól¬ 
nione na początku programu.” 

Podobnie jest ze zmiennymi 
przechowującymi teksty Czarno¬ 
księżnik uczył się tego podczas 
pierwszego wieczoru Teraz rozpo¬ 
czął od obmyślania planu działania 
prog.amu. aki plan nazywa się al¬ 
gorytmem. 

Jak zapewne wiecie, mila morska 
ma 1852 metry czyli 1 852 kilome- 
i ? v. 

Należy .więc 

V wczytać ilość mli 

2° pomnożyć tę ilość przez skalę 
1.852 iw językach programo¬ 
wania używamy Kropki dzie¬ 
siętnej a nie przecinka) 

3° napisać wynik 

Ponieważ chcemy, żeby program 
działał wielokrotnie ale me bez koń¬ 
ca, nu simy wykonać go w pętiu Je¬ 
dnocześnie ustalimy, że pętla za 
kończy swoje działanie, gay zerową 
ilość mi; zechcemy zmienić na kilo 
metry. 

Czarnoksiężnik usiadł wygodnie 
w fotelu, wziął do rąk tajemna Księ¬ 
gę i zaczął czytać. 

„Jednym ze sposobów zapętle- 
nia programu jest wykonanie instru¬ 
kcji w pętli „powtarzaj” Ma ona po¬ 
stać- 

powtarzaj (start; warunek; zmia¬ 
na) instr 

W pętli tej najpierw wykona się in¬ 
strukcja inicjująca „start” następ¬ 
nie, jeśli warunek jest prawdziwy 
(tzn. „warunek” jest różny od zera) 
to wykonają się instrukcje „instr” a 
po niej „zmiana i ponownie pro¬ 
gram przechodzi do sprawdzenia 
„warunku”. 

Jeśli chcemy w pętli wykonać kil¬ 
ka instrukcji, wtedy „instr” jest blo¬ 
kiem kilku instrukcji ujętym w na¬ 
wiasy klamrowe {} Każda instruk¬ 
cja musi kończyć się średnikiem,. 

Trzy elementy w nawiasach () na¬ 
zwiemy instrukcjami sterującymi 
zaś „instr* nazwiemy treścią pętli 
Każdy z tych elementów może byc 
pusty tzrs. może go nie byc Musi 
pozostać jednak średnik oddzielają¬ 
cy poszczególne Aementy Jeśli 
brak start” to me wykona się in¬ 
strukcja inicjująca Jeśli brak „waru¬ 
nku to przyjmujemy, ze jest praw¬ 
dziwy Jeśli brak jest „zmiany to 
znacz za pętla ponownie wykona 
się br zmiany parametrów sterują¬ 
cych. Najczęściej tak bywa, gdy 
zmiany tej dokonujemy w treści 
pętli (czasami tak jest wygodniej) 
Brak treści pętli „instr” zdarza się 
wtedy, gay instrukcje sterujące wy 
konają wszystkie czynności przewi¬ 
dziane do wykonania w tej pętli. W 
szczególności instrukcja 

powtarzaj (; ;) : 

mc nr wykonuje i jednocześnie 
pracuje bez końca. 

Instrukcje sterujące „start i 
„zmiana” mogą składać się z kilku 


części Oddzielamy je od siebie 
przecinkiem 

Jeśli któryś z elementów instruk¬ 
cji „powtarzaj jest zbyt długi i nie 
mieści się w jednym wierszu to mo ¬ 
żna go napisać w kilku wierszach 
dzieląc według własnego uznania 
W szczególności instrukcja ta może 
byc napisana w formie- 
powtarzaj (start; 
warunek; 
zmiana) 
instr; ” 

Czarnoksiężnik odłożył księgę, 
po czym usiadł do komputera 
— Najpierw uzupełnię zbiór cza¬ 
rodziejskich zaklęć — pomyślał. Do 
utworzonego podczas pierwszego 
wieczoru zbioru <predef h> dopisał 
kolejne zaklęcia wybrane z księgi 

# define rzeczywista float 

# define całkowita int 

# define precyzyjna double 

# define diuga long 

# define powtarzaj for 
Teraz zamyślił się głęboko 

— Gdy wczytywałem lub pisa¬ 
łem teksty to w odpowiednim miejs¬ 
cu funkcji „czytaj” iub „pisz 1 pisa¬ 
łem %s Co powinienem napisać w 
przypadku liczb? 

Otworzył księgę i czytał 
„Funkcje „czytaj” i „pisz* mogą 
oprócz tekstów obsługiwać także li¬ 
czby W przypadku, gdy chcemy 
wczytac lub napisać liczbę, należy 
zaznaczyć to w odpowiednim miej¬ 
scu tekstu zaś po cudzysłowie na¬ 
pisać nazwę zmiennej, gdzie jest 
lub będzie przechowywana dana 
wartość. Zaznaczenia dokonuiemy 
w zależności od rodzaju liczby: 

%ri — wartość jest całkowitą licz¬ 
bą dziesiętną 

%f — wartość jest rzeczywistą 
liczbą dziesiętną 

%c — wartość jest pojedynczym 
znakiem pisarskim 

%s — wartość jest ciągiem zna¬ 
ków pisarskich (tekstem) 

Gdy wartość jest liczbą o rozsze¬ 
rzonym zakresie, to odpowiednio 
przed literami „d” i „f należy napi¬ 
sać literę „I” ” 

Oczywiście, w księdze byłe wię¬ 
cej informacji o formacie danych, 
dziś jednak poprzestaniemy na tym 
Teraz nasz znajomy zaczął ob¬ 
myślać szczegóły programu 
— Jeśli chcę w pętli przeliczać 
mile na kilometry, to instrukcja 
„start' powinna wczytac ilosc mil, 
„warunek 1 powinien sprawdzić, 
czy ta ilość jest rożna od zera, 
„zmiana powinna ponownie wczy¬ 
tac ilosc mil a „instr powinna prze¬ 
liczać miie na kilometry i wypisać 
wynik.—. 

— No to do roboty — pomyślał, 
odłożył księgę i niby pianista, oparł 
palce na klawiaturze. Na ekranie 
powstawał tekst programu: 

<inc!ude stdio h> 

<include preder h> 
majster 

; całkowita mile; 
rzeczywista kilometry, 
powtarzaj (czytaj(”%d”) f mile): 
mile !=0, czytaj(”%d", mile)) 
{kilometry = mile * 1 852, 
pisz( ! %d” mile = %f kilo¬ 
metry ', miie. kilometry); } 

} 

Nowością w tym programie jest 
zapis 

mile i-- O 

który czytamy „Miie rożne ca 
zera” Symbol O oznacza zero 
(przekreślone dla odróżnienia od li¬ 
tery „O” Symbol ”! = " jest opera¬ 
torem logicznym, Które będą omó¬ 
wione w następnych odcinkach 

Mieczysław Płacheta 
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KLAN KALKULATORÓW HMMNMKMMMIIMMNHMMHNUMI 


I METODY NUMERYCZNE 
DLA KALKULATORÓW 
PROGRAMOWANYCH 
AOS I RPN 


I. RÓWNANIA ALGEBRAICZNE. CZĘŚC 1. 

Wstęp. 

Iteracja na'ezy do grupy tych dz ałan w obręb“e metod numerycznych, które 
najskuteczniej przekonują nas o korzyściach płynących z zastosowania kalku¬ 
latorów programowanych do wykonywania obliczeń wymagających wielokrot¬ 
nego stosowania określonej operacji matematycznej. O jej randze świadczy 
fakt, ze jest ona jednym z najważniejszych narzędzi tak praktycznego jak i teo¬ 
retycznego badania problemów liniowych i nieliniowych. O tych zagadnieniach 
traktować będzie seria kolejnych artykułów 
Teoria. 

Metody iteracyjne wyznaczania zera I funkcji f(x) polegają na konstrukcji 
ciągu kolejnych przybliżeń x 0l x 1( ... zbieżnego do X. 

Postać m — punktowego wzoru iteracyjnego jest następująca 

x Ml - g (x, X; 1( . x, mn ) '^ni-1 IM 

Jeżeli funkcje g, — generujące ciąg IM nie zależą od i, wówczas metoda okre 
słona wzorem7l/ jest metodą stacjonarną Jeśli postać funkcji g zmienia się 
od jednej iteracji do drugiej, to metoda jest niestacjonarna 

Istnieje kilka metod pozwalających na skuteczne rozwiązanie tego problemu. 
Do najbardziej znanych naiezy 
1. Metoda Newtona-Raphsona (stycznych). 

Metoda Newtona-Raphsona jest stacjonarną metodą jednopunktową Aby 
rozpocząć obliczenia, należy wyznaczyć przybliżenie początkowe x 0 zera I 
Metoda Newtona Raphsona będzie zb i eżna, tzn x-»ł, jeśli początkowe przy¬ 
bliżenie x 0 będzie dostatecznie bliskie I Posiada ona bardzo prostą interpreta 
cję geometryczną Mianowicie przybliżenie x +1 jest punktem przecięcia osi 0x 
ze styczną do wykresu funkcji f(x) w punkcie x 
Kolejne przybliżenia x. zera 2! funkcji f(x) oblicza się z wzoru: 

x i+l = X - f M i^O 121 

f’W 



2. Metoda siecznych. 

Niech x 0 i x, będą dwoma kolejnymi, początkowymi przybliżeniami zera X 
funkcji f(x) Wówczas następne przybliżenie można obliczyć z wzoru 


X, f-2 = X 14l 


X,U1 - X, 
^(Xj+i) f(Xj) 


f (x +1 ) 


i^o 


/ 3/ 


Proces ten będzie zbiezny, jeśli x 0 i x 1 będą dostatecznie bliskte zera Kolej¬ 
ne przybliżenie x j+ jest punktem, w którym sieczna funkcji f(x) poprowadzona 
w punktach x i x iH , przecina os 0x ^est to metoda stacjonarna dwupuriktowa. 



Interpretacja dla kalkulatorów z Algebraicznym Systemem Operacyjnym 
AOS™. 

Oddajmy pierwszeństwo metodzie Newtona-Raphsona, Która jest częściej 
stosowana w praktyce obliczeniowej 

Program umożliwiający obliczenie pierwiastków równania został opracowany 
na model TI-66 Program mable i przedstawia s ę następująco 



tab 1 

Jego realizacja przebiega w kilku etapach które charakteryzuje tabela 2 


Kolejność działań 

Komentarz 

<7TO r ł1 LRH 

P(x) 

IHV] 1 SBS 

| LBL |2nd| E | 

F(x) 

fiNv sbrJ \im 

Z 0 A 

i B 

B 

podprogramu 

Skok bezwarunkowy do etykiety E . 
wprowadzenie modułu LRN , 
seria instrukcji klawiszowych 
wprowadzających funkcję f(x) 

Instrukcja zamykająca podprogram E 

Skok bezwarunkowy do podprogramu E f 
seria instrukcji klawiszowych 
wprowadzających pochodną funkcji f(x 

Instrukcja zamykająca podprogram E 
wyjście z modułu I&N 

Wprowadzenie pierwszego przybliżenia 

pierwiastka równania 

Wprowadzenie liczby aproksymacji 

Wykonanie programu 


tab, 2 


Przykład 

Obliczyć pierwiastki rzeczywiste funkcji f(x) = 3x - 3x - 2, korzystając 
z metody Newtona-Raphsona. 


GTO| 

E J 

LRN 



( | 

[rcł] 

1 X 2 ] 

[*1 3 

- i Jhcl) i 

INV 

1 SBK | 




| ŁBL 

2 nd | 

Tl 



1 (J 

|rcł| 

t X 

6 [Z! 

3 m 




| INV j |~SBR 


LRN 



Ponieważ nasza funkcja jest wielomianem stopnia drugiego zakładamy, ze po¬ 
siada 2 miejsca zerowe Po wprowadzeniu do kalkulatora wartości pierwszych 
aproksymacji pierwiastków równania, kolejne przybliżenia ich rzeczywistych 
wartości podają tabele poniżej 



0 

1 A 1 


1 

A | 

i 

1 B 1 

— 0.066666667 


1 

1 B | 

1.66666666 7 

2 

lu 

- 0.457607433 


2 

LU 

1.457607433 

3 

m 

- 0.457607433 


3 

m 

1.457607433 

4 

1 B ! 

- 0.457427108 


4 

1 B | 

1.457607108 

5 

• 

1 B | 

- 0.457427108 


5 

m 

1 B 1 

1.457607108 

• 

10 

Tl 

- 0.457427108 


• 

10 

□P 

1.457607108 


Janusz Mitura 
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UIYSZUKIUIANK, 

W ciągu ostatnich kliku tygo¬ 
dni parę osob pytało mnie o 
efektywne algorytmy sortowa¬ 
nia. Problem może byc błahy 
jeśli chodzi o uporządkowanie 
np. w kolejności rosnącej co 
najwyżej kilkudziesięciu da¬ 
nych numerycznych. 

Kłopoty pojawiają się gay mamy do czynienia 
ze zbiorami danych (ang files) o wielkości prawie 
takiej jak pamięć operacyjna naszej maszyny Tu 
juz nasze „prywatne ’ algorytmy me wystarczają i 
trzeba sięgnąć po literaturę fachową, w której też 
me zawsze potrafimy znalezc algorytm najefekty¬ 
wniejszy czyli najszybszy Do momentu, w któ¬ 
rym się me zainteresowałem tym problemem 
uważałem, ze najszybszymi algorytmami są me¬ 
toda Shell a i Bąbelkowa (ang Bubblesorting) 
wraz z mutacjami. Jakież było moje zdumienie 
gdy po dotarciu do odpowiednich źródeł, opro¬ 
gramowaniu, uruchomieniu i przetestowaniu kilku 
nowych algorytmów okazało się ze metody te są 
wolne jak żółw w porównaniu z metodami tzw. 
HeapSorting czy GuickSorting Zacznijmy jednak 
od początku 

Najprostszą postacią struktury charakterystycz¬ 
ną dla danych są tak zwane zbiory danych Zbiór 
danych składa się z szeregu zapisów (ang re- 
cords), które z koleś mogą składać się z pewnej li¬ 
czby poi (ang fieids). Przykładami zbiorow da¬ 
nych w zycsu cooztennym może być kartoteka za¬ 
wierająca w sposob usystematyzowany nazwiska 
osob, ich adresy i inne dane lub też słownik w 
którym każdemu hasłu odpowiada jakiś zapis wy¬ 
jaśniający 

Jednym z najprostszych procesów jakie dają 
się określić w odn esieniu do zbiorow danych jest 
proces wyszukania danych 

Problem wyszukiwania powstaje wtedy gdy 
trzeba zidentyfikować zapis za pomocą pewnego 
klucza (pewnej części identyfikowanego zapisu). 
Przyjmuje się, ze rożne zaoisy mają rożne klucze 
i wszystkie odstępstwa od tej zasady muszą być 
wyraźnie sygnalizowane. Wyszukiwanie jest więc 
procesem lokalizacji pewnego zapisu w obrębie 
danego zbioru na podstawie klucza tego zapisu 
np w zbiorze nazwisk i adresów mamy znalezc 
pełny zapis odpowiadający jakiemuś nazwisku 
Wyszukiwanie określa się jako pomyślne, gdy za¬ 
pis poszukiwany został odnaleziony, w przeciw¬ 
nym wypadku określa się je jako niepomyślne 
Aby dac jakieś wyobrażenie o wyszukiwaniu 
przedstawię dwie metody: 

— wyszukiwanie proste — Przy zastosowaniu 
tej metody przyjmuje się. że zapisy umieszczone 
są w pamięci w sposob zwarty, tworząc wektor 
lub tablicę, przy czym porządek w jakim występu¬ 
ją klucze zapisów me jest z góry znany. W takiej 
sytuacji można się posłużyć jedynie metodą wy¬ 
szukiwania prostego: zapis\ pobiera się ze zbioru 
pojedynczo w pewnej określonej kolejności; w 
każdym pobranym zapisie sprawdza się, czy jego 
klucz zgadza się z kluczem zapisu poszukiwane¬ 
go, jeśii me ma zgodności proces prowadzi się 
dalej az do wyczerpania całego zbioru zapisów. 
Zaletami tej metody jest oprócz jej niezwykrej 
prostoty możliwość rozbudowywania zbioru da¬ 
nych przez dopisywanie. Można też w sposob 
bezkonfliktowy skreślać określone zapisy jeśli 
wyszukiwanie jest zorganizowane w ten sposób 
że zapisy puste są pomijane. Wadą tej metody 
jest jej powolność. Liczba cykli wyszukiwania 
(ilosc porównań zapisu z kluczem) wynosi 1, jeśli 
od razu trafia się na zapis poszukiwany, oraz wy¬ 
nosi N (liczba zapisów w zbiorze danych), gdy 
poszukiwany zapis znajdował się na końcu zbio¬ 
ru. Tak więc średnia liczba cykli wyszukiwania dla 
pomyślnego wyniku wyszukiwania jest wartością 
podanych wyżej liczb. 
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Średnia liczba cykli w wyszukiwaniu prostym - 
(1 +N)/2 Gdy N jest małe lub gdy powolność al¬ 
gorytmu może byc tolerowana wskazane jest 
użycie tego algorytmu ze względu na jego logicz¬ 
ną prostotę 

— wyszukiwanie binarne — jest to ważny 
przykład wyszukiwania dychotomicznego. Rozu¬ 
mie się przez me proces, w którym każdy cykl 
wyszukiwania łączy się z podziałem zbioru lub tej 
jego części, która może zawierać poszukiwany 
zapis, na dwie części, po czym jedna z tych częś¬ 
ci może byc odrzucona Przy zastosowaniu tej 
metody zapisy można przechowywać w pamięci 
w postaci zwartej tablicy, która powinna byc upo¬ 
rządkowana według kluczy zapisów Zakłada się 
więc, ze na zbiorze kiuczy jest określona pewna 
relacja porządkująca, pozwalająca bezpośrednio 
określić dla każdych dwóch rożnych kluczy, który 
z nich jest wcześniejszy w danym zbiorze Każdy 
cykl wyszuk wama binarnego pociąga za sobą 
zmniejszenie części zbioru, w której może znaj¬ 
dować się poszukiwany zapis o połowę w stosun¬ 
ku do części poprzedniej Objaśnia to pochodze¬ 
nie słowa „binarna 5 Średnią liczbę cykli wyma¬ 
ganych dla pomyślnego wyniku wyszukiwania 
można w przybliżeniu otrzymać w następujący 
sposób ponieważ każdy cykl zmniejsza zbiór o 
połowę to po wykonaniu n cykli pozostaje w zbio¬ 
rze N*21(-n) zapisów. Wyszukiwanie kończymy 
gdy pozostaje nam tylko jeden zapis ten poszuki¬ 
wany Osiąga się to po n cyklach przy czym n o- 
znacza najmniejszą liczbę całkowitą, która spełnia 
merownosc N*21(-n) =1. Stąd otrzymujemy, 
że logN< = hczba cykii wyszukwama binarne- 
go<=1-HogN log jest logarytmem o podstawie 
równej 2 Ponieważ przy szybkim wzroście N lo- 
garytm rośnie powoli widać z tego, ze dla dużych 
N wyszukiwanie binarne jest bardziej ekonomicz¬ 
ne mz wyszukiwanie proste (oczywiście jeśli po¬ 
mija się koszt utrzymania zbiorow w stame upo¬ 
rządkowanym). 

Kolejnym procesem odnoszącym się ao zbio¬ 
rów danych jest porządkowanie wewnętrzne, 
czyli sortowanie Porządkowanie wewnętrzne 
zbioru jest takim przemieszczeniem zapisów w 
wyniku którego klucze następują po sobie w pew¬ 
nej ustalonej kolejności Jednym z zastosowań 
porządkowania jest przygotowanie zbioru do pro¬ 
cesu wyszukiwania binarnego. Takie przekształ¬ 
cenie zbioru często nazywa się sortowaniem a 
me porządkowaniem. Sortowanie wymaga, na 
ogoł przemieszczenia zapisów, przy czym każdy 
zapis może kilkakrotnie zmienić swoje miejsce 
zanim me zostanie osiągnięte wymagane upo¬ 
rządkowanie zbioru Dla realizacji procesu sorto¬ 
wania są potrzebne tylko klucze sortowania, które 
pozwalają okreśt ć sposób postępowania w tym 
procesie. W przypadkach, w których kiucz stano¬ 
wi stosunkowo niewielką część dużego zapisu, 
można zaoszczędzić sporo czasu, gdy podczas 
sortowania traktuje się klucze me jako elementy 
pełnych zap sów lecz jako składniki nazwijmy to 
skorowidza, zawierającego odniesienia do peł¬ 
nych zapisów. 

Jak juz wspomniałem na wstępie, istnieje wie.e 
użytecznych metod sortowania. Najlepsze spo¬ 
śród tych metod są na ogoł jednocześnie bardziej 
ekonomiczne choć często osiąga się to kosztem 
wielkości potrzebnej pamięci i złożoności logicz¬ 
nej algorytmu Dlatego tez określenie miary jako¬ 
ści przy systematycznym porównywaniu metod 
napotyKa na trudności. Wybór „najlepszej” meto¬ 
dy sortowania zbioru zależy od dostępnej infor¬ 
macji odnoszącej się do stopnia uporządkowania 
zbioru, co stanowi dodatkową komplikację. Oczy¬ 
wiście efektywność aigorytmow zależy od złożo¬ 
ności zbioru danych, od tego czy sortowaniu po 
dlegają liczby czy leż teksty (problem reprezenta¬ 
cji i interpretacji tychże w komputerach) ito 

Poniżej chciałem przedstawić algorytmów 
sortowania. Moim zdaniem są to najlepsze algo¬ 
rytmy o prostej budowie, a więc umożliwiające 


ISOATOIIIANK 

korzystanie z nich na mikrokomputerach. Algoryt¬ 
my przedstawiam jako procedury (o nazwach al¬ 
gorytmu sortującego) napisane w Pascal-u Poni¬ 
żej wszystkich aigorytmow przedstawiam test 
szybkości tychże Test został przeprowadzony na 
komputerze Commodore 128 dla rożnej wielkości 
zbiorow 

100, 200, 300, 400, 500 1000, 2500, 5000, 
10000, 30000 elementów (wielkość zbioru prze¬ 
chowywana jest w zmiennej Numitems) 
Sortowaniu podlegały liczby xx z przedziału (0 9999) 
generowane w sposob losowy i przechowywane 
w wektorze Sort-Array-Type. Wektor ten definiu¬ 
jemy w programie głównym w następujący spo¬ 
sob 

Type Sort-Array Type = Array [O Numitems] of 
mteger; Wynik czasowy dla danego zbioru jest 
średnią arytmetyczną czasów uzyskiwanych przy 
nmbach sortowania (chyba, ze czas ten prze¬ 
wyższał 2 godziny, wtedy bowiem program steru¬ 
jący przechodził do testowania następnego algo¬ 
rytmu) Wynik testu podawany jest w formacie 
gg/mm/ss czyli godz ny/minuty/sekundy 


"ar 1. l,H,Xo : Ln+eger ; 

Regin 

For 1 := 2 to Hurra terns do 

For 3 := Numi tenis Down fo f do 
Ił hL,i —1J hEJJ (hen 
Beair i 

KS := hL.I- i 1, 
hLJ - l : — h [. J I; 

uL‘J 1 s= X3: 
t"nd; 

tnd; 

hrocedi 'i e ShakerSorł. '.‘ar i : ,r f — nr » ag- f yj.«e ; 

Dar ij . 1 , L , R. X5 : I nfcecjer . 

Beg 3 r i 

L. ;= 1; R : — Hurra tems; I . uurra tene; 

Repeat. 

For 3 s— R Down To L do 
[ f oL.T-13 hL3 J t hen 
Reg j. i. 

X3 := hLJ 1 i; 

AU - 1 _! : hL.i a 
mL3 3 := X3; 

V : = J ; 

£.i id i 

L := K+.U 

F of a : - l To R on 

I f m[ 1 J hI 3 3 I ne. 

Beg n 

Ho hL.:i- 1 J- 
i iC.JI-j 3 : = HL.I 3: 
hL.i I : = X Sl 
1 : ■" J ; 

tnd: 

R : - L — 1: 

Ur ifc i i L.. H : 


f "o iceaur e im er t_ionSor* • '.-ar u - ł hi t ag - I gnn •: 

ar I . i, X : 1 n ł .,eg* r; 

fó-g i n 

For ] : — X To Huna tani do 

Reg i n 

X : = h L i J; h L n : - ; : - ! 

Uhi 1 e X h L3 j dij 
Bieg m 

FtL3 + i 3 : = !-u i 3; 

3 : = 0-1; 

£ nd; 

hLJ + 1J := 1; 

tu J; 

t i: 


L “ ed! If •- Bill li I.J 1 n i ■ >r i' .nr ,r 

i: , I , R , ! i, . i I! . ■! 

Regi r ■ 

F. .i : ■ r... 


; hLJ i; . ; ; 

Uhl 1 o k 

R-- j i r 

11 : - • u+R 
It HLo 1 1 H-. . 

R N-l 

tl.e : .-'I- 

b nd; 

Of 3 : = I — l l mui ■ • J. > 

Beg i n 

h C3 + 13 : — m L ' 3; 
hLL 3 : i: 

tnd; 

F ncl: 

t r.d; 

ri ócedut *- Se i ©cl lom-or t 1 '.'ar u • '-_or h — hh- =,' j Tar.. ■: 

-ar ! . I . r , : i r sRe jer ; 
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D!a dwóch ostatnich algorytmów dla N = 10000 
otrzymałem odpowiednio 359 i 148 a dla 
(SN30000 odpowiednio 1340 i 618 

Dla tak dużych zbiorow pozostałe algorytmy nie 
dawały rezultatu nawet po 6 godzinach 

Przykładowy odczyt dla N=5000 i algorytmu Se- 
iectionSort: 1 godzina, 55 minut, 10 sekund. 

Przykładowy odczyt dla (SN100 i aigorytmu Bub- 
bleSort: 6 sekund 


Dominik Falkowski 


B*ci r. 

K -- I; : - mL I J; 

0 := T + ł To Humi teras do 
Ił hCJ K Tren 
Be o i n 

ł ; — . j ; X : - 0 C ■ J j; 

End; 

hL( j : = hLI J: 
hCI s= 

End; 

i- i id; 

r tdui’!: He<śpSort ■■ Mar h : Surt-Hrr ag- I yp. ; 
M jr L, R, X. X3 : I nteget ; 

P r o ce cure 11 1; 
l abe1 13; 

Mar 1 , J ; Irrteger; 

Beg i n 

1 : = L; .3 : = _#1 ; := hEI j; 

Hhji* 1 = b do 

Begir i 

1 t J b, Thefł 

It Hi i I hL-J+IU Ineri 
: - 3+1 ; 

Tl A = hLJJ rtien 
GoTo 13; 
hL 1 3 := hL3 j; 

I : = 3 ; 

3 : = * I ; 

Łnd; 


13: hL 3. 3 : = 
t na. 


Beg i n 

1 j = >3+ iriii tent Di o 2- ł 1; R := Huniitess 
Bhile L J da 

Bogi n 

1 : - LI; Bit + ; 

Łnd. 

Uhi1e R 3 a 

Beg 111 

X3 hC1J; 

hTI 3 : = hCP. J; 

hCR3 := X3; 

P -= R-1; 

End; 


Procedurę Uuiocbor * .t h : sor t -h> r ay— I uue ! ‘ ; 
procedurę Bort L.r : Jnteger ; 

11 a 1,3, X: 1 rit ega ; 

Beg n i 

I ; = L.; 3 ! = K: 

; - hL L+HT Dl u ^.3: 

Repeał 

While uLIJ - 1 A. au 

1 1+1; 

Wbnl e X hlJ 3 do 
3 ; = 3-1; 

Ił I ~ 3 Then 
Begi r i 

X3 := hLI 3; 
hCI 3 := hl3 3; 
hC3 J := X3; 

I t+1; 

3 : = 3 - 1; 

End; 

Urit 1 1 I 3 ; 

Ił L 3 Thei 
Sort ■,L., 3 ,; 

Ił 1 P Tl,en 
Sor t t 1, R ; 

tnd; 

Beg i n 

Sor t cl, Hum 11 eme >; 

Ena; 


h 1 gorytm / H 
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181 

Vfc10I 

— I 

- 

i 

— 











i 
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SI 
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tl 

2 

i 

SI 
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3^1 

501 
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91 Z J 

11537 
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Se1ectionSort 
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3 
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11 i 

251 

451 

1101 

43912 

8531 

1 551U 
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HeapSort 
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1 

i 

21 

41 

61 

81 

171 

5tU 

1 50 
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Glui ckSort 

10 

. 5 

i 

1 I 

21 

31 

41 

81 
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Sm 
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00-443 WsrKiswn ul G6rnoiifsh« 9/11 t«l 21 

-56-oa 

Uk »l-72 

~45 

P 

r o g r a m 

y 

5 

1 

s 

3 

X 

ł? 

\ 

g 

Edukacyjne 


I 

5 

i 

O X OD>\ — 1 

AnLaot+ony fila Uts*trujęcy 

rjaulsks na tfau p n 

19 OOO 


X 


z 

ELEKTRONI K /V 

Ilustrowany tost s »U»ktroniki, uczący pud&ta 
wowycb pojyć 1 symboli «l«ktronlcwiych 

io OOO 

>c 



3 

grawi r/\c y a 

Syaulacja tajsanago oddziaływania dwóch etat 
w lctl polu grawi tacy Jkiya 

e ooo 

X 



4 

KINFMATYKA 2 
bal lat brzotit prograoów na twat 
pola grawltacy>Mgo 

a ooo 


X 


*5 

. SO<32:)FWKX 

PuwaŁaManl* obrazów rzsczywlatycb i pozoroycfc 
w socjwwkacb wklęsłych 1 wypuJtb ch 

5 OOO 

X 



a 

FUNKCJA LINIOWA 

Wlzaaarakri wykrotu funkcji lliUowaj oraz wpływ 
wt^ółcrywlków na wy kra*. 

6 OOO 

X 



7 

F* RZE K ROJ Łt 

uraficzna przadslawlanla przakrojów brył 

gaooatt ycznych Projaktowanla własnych brył 

e ooo 

X 

X 


© 

STOLICE EUROPY 

Gra dydaktyczne ucząca połotan ta 
stolic paAstw Europy 

u ooo 

X 



9 

ORA MA TYKA 1 

ćwiczaanla z logliznago 
rozbioru zdoó 

7 OOO 

X 



1 O 

jęZYK AMOIELSKX 
Tluaaczanla 1 wymowa Lxla.fi w oparciu 
o podrf+znU LSzkutnlka 

a ooo 


X 

X 

1 1 

k ról o w r r:. polski 

Nauka ko Jar :«nia faktów hłt o»y znych z o kr u 
saai pajkowanie powz z«g >lr;ych królów Polski 

6 OOO 

X 



JAK KUPOWAĆ PkOCRAMY ? Indyw dualrilo za gotówką lub 

pocztowym - Instytucje Łn gotówką lub czekiem Cany programów 
•ny nocników Ma iyccunla ajkOwtw lo raallsujoay noAnfkacfe 

katalog wru i krótkimi opisami wysysamy gratis 

za zaliczania* 
ola za w lara Jf 
kliontdw Pa łan 




ATARES 

Spółka z o.o. 

Chorzow, ut. Jesionowa 3 
teL 465-719 

oferuje: 

użytkownikom IBM usługi programistyczne 
na zamówienie zgodnie z indywidualnymi 
wymogami klienta 

Użytkownikom Atari najnowsze rozwiązania 
sprzętowo programistyczne jak 
kasetowy system transmisji „ BLIZZARD TURBO” 
6000 bodow (magnetofon po przeróbce 
czyta 10x szybciej, praKtycznte bez błędów) 
system digitalizacji dźwięku „CRYSTAL SOUND , 
cartridge do obsługi systemu „BLIZZARD TURBO”, 
TOP DRIVE 1050 (format 180 KB transmisja 70 KB), 
MAXI URBO DRIVE (kopiuje wszystkie zabezpiecze¬ 
nia, zabezpiecza wszystko) 

ATARI 256 DUAL SYSTEM (umożliwia pracę 
równoczesną z kilkoma programami-systemami), 
rozszerzenia pamięci A ARI, naprawę sprzętu 
ATARI najnowsze oprogramowań a ATARI. 
COMMODORE SPECTRUM 

Firma prowadzi skup — sprzedaż 
Komputeiow domowych, sprzętu RTV ; viaeo itp. k-106 


JAK REKLAMOWAĆ SIĘ 

W BAJTKU? 

Reklamy przyjmuje Biuro Reklamy „Sztandaru Młodych", 
Warszawa 1, skr pocztowa 363 : ul. Wspólna 61, te! 28- 
02-56 

Cena reklamy czarno-białej wynosi 750 zł za cm Do 
ceny podstawowej doliczane jest 30% za dodatkowy 
kolor i 100% w przypadku reklamy wielobarwnej. 
Ogłoszenie drobne kosztuje 450 zł za 1 słowo 
Wyżej wymienione kwoty można również wpłacić 
bezpośrednio na konto MAW Państwowy Bank 
Kredytowy w Warszawie, Ili Oddział Warszawa 
nr 370015-5757. 

W miejscu na korespondencję prosimy zaznaczyć ze wpłata 
dotyczy ogłoszenia w Bajtku Ogłoszenia drobne oddawane 
są do druku po otrzymaniu dowodu wpłaty z NBP 

Ceny te obowiązują od stycznia 1989 roku 


Wymienię- programy dla SPEC¬ 
TRUM, ATARI, COMMODORE. 
Janusz Walaszek, skrytka pocz¬ 
towa 1,33-106 Tarnów 8, 

(SB 25) 


SERWIS KOMPUTERÓW 

-TCST- 

40-164 Katowice ul Modrze¬ 
wiowa 24/33 
poleca naprawy 
ATARI 600, 800, 65,130 XL, XE 
C0M0D0RE 16 116, +4 64,128 
DlSC DR!VE 1541,1570,1571,1050 
MAGNETOFONY C0M0D0RE 
DRUKARKI 

godz. 9-11, 16-18. 

(SB 30) 


AGENCJA WYSYŁKOWA 

ELEKTRONICZNA 

A.S. SERW1CE ELEKTRONICS 

40-003 Katowice Teatralna 9 

• szukasz schematu Twojego kom 
putera, stacji dysków lub innego 
urządzenia 

• informacji katalogowej, względnie 
aplikacji elementów 

• a może podzespołów elektronicz¬ 
nych, układów scalonych 

Napisz, pomożemy Ci. 

(SB 35) 


MK&SYSKM 


Gdańsk ul K. Marksa 169 

tel (058)41-19-01 

proponuje 

• rewelacyjny system TURBO 
2000 przyspieszający współ¬ 
pracę z dowolnym magneto¬ 
fonem 

• sprzęt mikrokomputerowy 
ATARI XL/XE 

• interfejsy magnetofonu, Cen¬ 
tronics, TOP DRIVE, HAPPY 
WARP 

• sprzęt mikrokomputerowy 

ATARI ST 

• stacja dysków 5,25” 

• doskonałe, krajowej produk¬ 
cji monitory wielosystemowe 

| do ST (niskiej, średniej, wy¬ 
sokiej rozdzielczości) w ce¬ 
nie 299 000,- zł 

• sprzęt mikrokomputerowy 
COMMODORE 

ZADZWOŃ, NAPISZ, PRZY¬ 
JEDŹ I ZOBACZ 

(SB49) 


SPECTRUM TIMEX programy Adam 
Gruźlewicz ul. Działakowa 15, 96-300 
Żyrardów (G-51) 


MiKROSERVICE COMMODORE — 
64/128 AMIGA, ATARI, SPECTRUM 
IBM — PC/XT/AT 

INTERFEJSY — CENTRONICS RS 232, 
DIGITIZER FINAŁ, SPEEDDOS PRO¬ 
GRAMATORY 

EUROKARTY —Z80 6502,68000 A/C, 
CP/M 

01-911 WARSZAWA ANDERSENA 3/103 

D 52 


BAJTEK 7/89 25 
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Impreza, na której wmienes być obecni 



10 - 14 październik 7 89 
Hala Widowiskowo-Sportowa n Spodek"-Katowice 


- Informdt^)&d w 'Zó.\-z<xd'Z<iv\\u - XNF0 '89 

- Xhfbrnidt^&d w mcd^c^Hfe - XNF OMED 

- Mtedz^Hdrodow© sesje x udx\ót&m 

Stowdrz^sz^ioid D-ztenni/CdrzA) NduKi 

i Technik 

- S0VmMdryd -o iemat^ce : toformdt^&d 

di-<djo-v>d0o 

i&iwiyz ł a sdt0Xv'tdrHd 


(LeA/E>b dh^JLAAtf E^lpO O-EhL pX>-TU/^A^yi^ fe^ljl^KTU ó ItKjA&uj 


INF ‘ER 


Jestem zainteresowany:.....stoisko ookazowe 


stoisko informacyjne 


wtftniisfó a 


Nazwisko... 

Stanowisko...- 

Firma... 

Dziedzina zainteresowań 

ftdres. 


telefon...-. telex 


Adresat! 

Janusz Gołuch 
"PRO - INFO" 

40-001 Katowice 1 skr. poczt. 134/ 


tel. (832) 53-42-88 

tlli. 31E401 in-fo pi 


SB 15 
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Lot Hot bo GbseHt dł 


INFORMACJA 




10 - 14 october 1989 

Show Hall 'Spodek , Katowice Roland 


Ali the firms elektronics or informatics and willing to promote and present 
their products in Poland are welcome to participate in our Fair, 

Cleary then, the Show Hall Spodek 1 in October 89 is the place to be at if new 
business is your goal , For further infonnation please complete and return 
the coupon or telephone (832) 5342-88 or telex 312401 info pl. 


Now wed ({Keto he><t)r lnom 


I am intrested in =.eschibition stand 

..inforiaatian stand 

Wg me....... 


Position... 

Company--.-.-. 

Business Cotegory 
Bdress.......... 


Telephone...Tele x 


to: Janusz Goluch 

“PRO-INFO" Co. Ltd. 

40-001 Katowice 1 P.O.Bok 1347 
tel. (838)5348-88 tlx. 318401 mfo pl. 


SB 16 


















































CENY NA DZiEŃ 22.07.89 



Giełda 

Bajtka 

Sklep 

Bajtka 

Komis 

Pewex 

RFN 

Wlk 

Brytania 

CSH 
i inne 

tys zł 

tys zł 

tys zł 

$ 

DM 

# 

tys zł 

SINCLAIR 

ZX 81 

100 

— 

— 

— 

— 

— 

— 

ZX Spectrum 48 

380 

350 

400 

115 

80 

40 

— 

ZX Spectrum + 

420 

380 

440 

— 

90 

55 

— 

Timex 2048 

430 

— 

470 

146 

— 

— 

300 

ZX Spectrum 128+ 

— 

— 

— 

— 

— 

85 

— 

ZX Spectrum 128+2 

— 

— 

— 

— 

140 

100 

— 

ZX Spectrum 128+3 

710 

— 

— 

— 

280 

150 

— 

drukarka 

Seikosha GP 50s 

— 

250 

— 

— 

— 

— 

j 

-] 

Interface Kempston 

15 

10-15 

— 

— 

10 

9 

11 1 

COMMODORE 

. ..1 

Comrnodore 64 

700 

720 

740 

200 

290 

120 

— 

VC 20 

— 

200 

— 

— 

— 

— 

— 

C 16 

200 

300 

— 

— 

80 

— 

. ... -j 

C 116 

250 

280 

— 

— 

70 

40 

i 

C Plus 4 

350 

400 

450 

— 

150 

— 

— ! 

C 128 

1000 

1000 


299 

399 

170 

_ i 

C 128 D 

2000 

— 

— 

— 

820 

250 

j 

1 

Amiga 500 

2500 

2900 

— 

450 

899 

280 

— 

Magnetofon 1531 

130 

130 

180 

48 

30 

49 

— 

Stacja dysków 1541 

580 

700 

— 

— 

355 

— 

— 

Stacja dysków 1571 

820 

800 

— 

299 

460 

160 

— 

Drukarka MPS 803 

550 

600 

— 

— 

260 

100 

— 

ATARI 

Atari 800 XL 

440 

500 

550 

— 

— 

— 

— 

Atari 65 XE 

450 

510 

570 

114 

100 

80 

— 

Atari 130 XE 

550 

700 

— 

199 

220 

110 

— 

Atari 520 ST 

1800 

2000 

— 

— 

— 

260 

_ | 

Atari 1040 ST 

— 

— 

— 

— 

1140 

499 

— 

Magnetofon XC 12 

130 

140 

— 

36 

40 

42 

— 

Stacja dysków 1050 

700 

700 

770 

185 

300 

100 


Stacja dysków 520 STM 

— 

500 

— 

— 

— 

120 

z! 

Drukarka 1029 

500 

650 

— 

— 

— 

— 


AMSTRAD 

Amstrad 464 mono. 

750 

700 

r 

! _ 

_ H __ 

350 

150 

— 

Amstrad 664 mono 

— 

900 

— 

— 

— 

— 

— i 

Amstrad 6128 mono 1 200 

— 

— 

— 

670 

220 

1 i 

i 

Amstrad PCW 8256 

_ 

— 

— 

— 


300 


Amstrad PCW 8512 

| 

— 

— 

— 


390 


Amstrad PCW 9512 

— 

- 

— 

— 

— 

450 

— 

Stacja dysków do 464 


! .. 


— 

380 

100 

i . 

SHARP 

Sharp MZ 700 

— 

400 

— 

— 

— 

— 

i 

j _ 

Sharp MZ 800 

— 

450 

— 

— 

— 

— 

— 

Dyskietki 5 25 cala 

25 

2 25 

3 

1 

07 

05 

4-9 

Dyskietki 3 5 cala 

8 

7 5-9 

8-10 

— 

5 

12 

9-10 

Dyskietki 3 caie 

12 

— 

— 

— 

r \i 

0 

2 

12 

Joystick 

25 

16 30 

20 40 

5 

10 

5 

18 

Monitor Neptun 

70 

80 

— 

— 

— 

— 

70 


** - v v • yyy y -r* n r n -r^] 



Tomasz Gul, lat 13. Pos ada mikro¬ 
komputer Atari 65 XE, stację dysków 
LDW 2000 Oprogramowanie ponad 
500 gier oraz około 100 programów 
użytkowych Proponuje wymianę lite¬ 
ratury oraz oprogramowania Adres 
36-100 Kolbuszowa Dolna 11 
Marek Zydorezak, posiada Spectrum 
48KB monitor Neptun 156B, magne¬ 
tofon, interfejs Kempston oraz Sinclair 
1 i 2, Cursoi i joystick. Posiada około 
800 programów w tym programy użyt¬ 
kowe Interesuje się piłkę nożną, ko¬ 
szykówką oraz informatyką Proponu¬ 
je wymianę oprogramowania i do¬ 
świadczeń z użytkownikami Spec¬ 
trum, Adres. 41-706 Ruda Śląska, ul 
Kosynierów 4c/7 

Mirosław Winczewski \cl 51. Posia¬ 
da ZX Spectrum oraz około 500 
programów i gier Proponuje wymianę 
oprogramowania. Ad?es: 44-100 Gli¬ 
wice ul. Bolesława Śmiałego 4 m I 
Stanisław Bejko, pros; o KontaKt po¬ 
siadaczy mikrokomputera /X 81, po¬ 
szukuje literatury oraz oprogramowa¬ 
nia. Adres: 67-100 Nowa Sól ul. 
Przvszłosci 3c/38. 

Paweł Borek, lat 17. Posiada mikro¬ 
komputer Comrnodore C-64, stację 
dysków 1541, monitor KOLOR BHC 
Nawiąże kontakt w celu wymiany pro¬ 
gramow oraz literatury, posada dużą 
ilość literatury w języku angielskim 
Adres. 55-200 Oława u' Chrobrego 
76/10 


Rafał i Jakub Palejczyk nawiążą 
kontakt z posiadaczami mikrokompu¬ 
tera Timex 2048 w celu wymiany do¬ 
świadczeń i oprogramowania Adres: 
66-400 Gorzow ul Kołłątaja 56 m 8 

Agata Kujath, lat 10. Posiada Atari 
800 XL, magnetofon XC 12, monitor 
Neptun 156 Oprogramowanie około 
140 gier oraz programy edukacyjne 
Proponuje wymianę gier. Adres 
71-302 Szczecm, ul Wrońsk ego 8/1 
Dariusz Łukasz, lat 17. Pos ada Atari 
65 XE stację dysków 1050 (TURBO), 
magnetofon XC 12 (BLIZZARD), oko¬ 
ło 800 gier i programow użytkowych. 
Pragnie nawiązać korespondencję z 
posiadaczami Atari w celu wymiany 
oprogramowania, doświadczeń i lite¬ 
ratury Adres: 43-346 Bielsko-Biała, 
ul. Biedronki 18 

Sławek Przybylski, lat 16. Posiada 
Timex 2048 oraz około 250 progra¬ 
mów Zainteresowania: informatyka. 
Proponuje wymianę programów i do¬ 
świadczeń. Specjalizacja programy 
kopiujące. Adres 71-401 Szczecin, 
ul Wyzwolenia 75a/62 
Cezary Konieczny, lat 26. Posiada 
Schneidera CPC 6128, stację dysków 
5 1 i A firmy Vortex (F 1 X). Oprogramo¬ 
wanie kilkaset różnych programów, 
m in własne programy projektowania i 
instalacji własnych znaków na drukarki 
zgodne z Epsonem (9 igłowe) w tym 
draft i NLQ 

Pragnie wymienić oprogramowanie 
oraz zachodnie czasopisma poświę¬ 
cone Amstradowi. Adres: 61-418 Po 
znań, ul Żerkowska 37 

Konrad Kwiatkowski, Sat 13, Posia¬ 
da ZX Spectrum + . Proponuje wymia 
nę doświadczeń, oprogramowania 
oraz opisow gier Adres. 09-402 
Płock ul Szopena 61 m 33 


OT; 



Mi 
U SNCTIIUM 

INSTRUKCJE • OPISY 
LITERATURA 


Szkoły i Kluby-zniżka 

Kata ogi-gratis 

Co piąty program-gratis 

Wysyłka na cały kraj 

Wypożyczalnia programów 

D.H Sezam lip godz 16-19 

00-849 Warszawa U PT 66, skr.p. 14 
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Na listy czytelników odpowiada 

Dominik Falkowski 



Jestem uczniem II klasy L.O. w Kwi- 
dzyniu. Interesuję się historią, głownie // 
wojny światowej i dlatego moją pasją są 
gry strategiczne dotyczące tego okresu. 
Poznałem na razie dwie, tzn. „Arnhem” 
oraz ,,Desert Rats” na ZX Spectrum. 
Chciałbym prosie o informację na temat 
innych gier tego typu. Jaka jest możli¬ 
wość dotarcia do większej ilości takich 
gier i oryginalnych instrukcji do nich 
(-■•)? 

Adam Nos ko, Kwidzyn 

Powstałe bardzo wiele gier strategicz¬ 
nych, gdyż te r a wojny i strategii pasjonuje 
w równym stopniu, jak programowanie Oto 
mini-lista najpopularniejszych gier tego 
typu, opracowanych na ZX Spectrum: 

D Day (lądowanie w Arnhem), 

Battle ot Brltain (bitwa o Anglię), 

Faiklands (konflikt ralkiaridzki), 

1 neatre Europę i^wizja III wojny światowej), 
Ooeration Hormutz (bliżej nieznana opera¬ 
cja), 

Tneir Finest Hours (c.zatnie chwile Niem¬ 
ców w Europie) 

jeśli chodzi o ich zdobywanie, to jedy¬ 
nym źródłem jest — niestety — giełda i ko 
leazy. Brak jest bowiem licencjonowanych 
kopii gier zachodnich, zaś polskie gry w za 
sadzie nie powstają Oczywiście nabijanie 
kiesy handlarzom tylko dlatego, ze „om 
mają, a ja nie" leży tu na granicy prawa i 
bezprawia, ale jak na razie mc nie udało się 
zrobić Podobnie ma ssę sprawa z instrukc¬ 
jami do gier, w przypadku zakupu legalne¬ 
go (oczywiście me w Polsce) do gry dołą 
czana jest instrukcja A my, jak na razie, 
musimy ratować się również giełdą, no i 
oczywiście „Bajtkiem” 


Od kilku miesięcy posiadam mikro¬ 
komputer TIMEX 204B. Jestem z niego 
zadowolony i nie zamieniłbym się na ża¬ 
den inny Poznałem już trochę jego mo¬ 
żliwości, ipcz na niektóre pytania wciąż 
nie mogę znalezc odpowiedzi (...). 

Mam sporo programów nagranych w 
systemie TURBO-COPY autorstwa Ta¬ 
deusza Wilczka. Interesuje mnie, w jaki 
sposob można je wprowadzić do pamię¬ 
ci, ponieważ podczas wczytywania z 
magnetofonu ani jeden program nie jest 
przez mikrokomputer przyjmowany. (...) 
Czy mogę bez obaw podłączyć mterface 
Kempston na dwa joysticki do T!MEX a ? 
(..) Czy można uzyskać dźwięk z kom¬ 
putera przez głośnik telewizora? (...) 
Czy można programowo wyłączyć głoś¬ 
nik w TlMEX-ie, by w nocy nie przeszka¬ 
dzać domownikom w spaniu? (...) Czy 
wyjdzie choc jeden numer specjalny 
„ Tylko o Spectrum? (...) 

Zbigniew Fronckiewicz, Poznan 


COPY-COPY komendą LOAD AT 
65000 po czym uruchomić komendą USR 
65017 Od tej chwili wszystkie odczyty i za¬ 
pisy na (z COPY COPY odbywały się będą 
w systemie TURBO Prędkość transmisji 
ustala się komendą PAUSE n gdzie n jest 
liczbą od 0 do 0/0 — najwolniej, 9 — naj¬ 
szybciej). 

W ten sposob mozesz wczytać swoje 

programy na COPY COPY i po zmianie 
prędkości zapisu nagrać je na taśmę w celu 
późniejszego uruchomienia W przypadku 
korzystania z dobrego magnetofonu, moz 
na wczytywać na czystą pam ęc programy 
nawet 3 razy przyspieszone System TUR¬ 


BO COPY służy do archiwizacji progra¬ 
mów, azięki niemu na jedne 1 taśmie prze¬ 
chowywać można nawet 100 programów* 

Interface Kempston powinien działać bez 
zarzutu z TIMEX~em, choc mogą zdarzyć 
się przypadki złej współpracy Tym niem¬ 
niej możliwość zepsucia TiMEX-a interfa- 
cem Kempston jest prawie żadna, choć w 
Twoim przypadku może się ujawnić ta jed¬ 
na na 100 szansa. 

Ani Spectrum, ani T!MEX nie podają syg¬ 
nału Audio na wyjście antenowe Tak w ęc 
uzyskanie głosu przez telewizor tak, jak na 
przykład w Commodore lub Atari jest nie¬ 
możliwe. istnieje przystawka o nazwie 
„Currah microSpeech”, której jedną z 
funkcji jest uzyskanie dźwięku przez głoś¬ 
nik telewizora. Jeśli chcesz wykonać to 
sam spróbuj połączyć wyjście MIC z gmaz 
dem „głośnikowym w telewizorze — cza¬ 
sem daje to rezultat Zas najprostsze z mo¬ 
żliwych wzmocnienie głosu uzyskasz po¬ 
dłączając MIC do gniazda mikrofonowego 
magnetofonu, odłączając kabel EAR-gmaz- 
do słuchawkowe Po włączeniu magnetofo¬ 
nu na nagrywanie (bez kasety!) z jego głoś¬ 
nika popłyną dźwięki Co do wewnętrznego 
głośnika TlMEX-a, to jego odłączenie pro¬ 
gramowe jest niemożliwe, zaś sprzętowe 
ogranicza się do użycia lutownicy (raz na 
zawsze) lub wbudowaniu przełącznika w 
obudowę mikrokomputera 


Ulegając namowom Czytelników na te¬ 
mat numeru specjalnego o Spectrum, 
zmieniliśmy zdanie i numer tak ukaże się. 
Nie nastąpi to jednak szybko, bowiem w 
przygotowaniu! są na razie następujące nu¬ 
mery specjalne Atarii III, Gry II, Commodo¬ 
re II i Atari IV „Bajtka” tylko o Spectrum 
spodziewajcie się więc pod koniec bieżące¬ 
go roku 


Chciałbym wiedzieć, w jaki sposob 
tworzy się efekty specjalne na ekranie, 
jak tworzyć procedury przerwań, gdzie 
one się znajdują w pamięci i w ogolę 
wszystko o przerwaniach. Proszę o 
wydrukowanie krótkiego programu ry¬ 
sującego koła w trybie graficznym 7. Bar¬ 
dzo proszę o doradzenie mi jakiejś książ¬ 
ki z zakresu mikroprocesora 6502. 

(nazwisko i adres 
do wiadomości redakcji) 

Odpowiedzi na pytania zawarte w liście 
zapełniłyby prawie cały numer „Ba|tka” 
Niektóre z tych tematów były już poruszane 
w naszym piśmie. Polecam Ci lekturę ksią 
zek warszawskiego SOETO „Asembler 
6502” oraz „Poradnik programisty Atari 


IBM XT, AT/386 
COMMODORE 
ARRI 
SPECTRUM 
(TIMEX) 

Sprzęt, programy, opisy 
ATUT Sp. zoo 
ul. Weteranów 38 
20-045 Lublin 

K 133 


ATASERW 

42-100 Tychy 
ul. Lencewicza 46/3 
Tel. 27-69-66 

oferuje świetne rozwiązania 
sprzętowe 
do ATARI XL/XE 

1 TURBO DOS-wspamały DOS 
na kartidzu 

2. TOP DRIVE 1050 samodzielny 
montaż /recenzja IN FOR MIK 111/883 

3 INTERFEJS CENTRONIKS 

4 ROZSZERZENIA PAMIĘCI 

5. BASIC XE-kartridż 

6. PROGRAMATOR EPROM 
7 PROGRAMY UŻYTKOWE 

12 miesięcy gwarancji. Informa¬ 
cje i zamówienia telefonicznie 
(wtorek 8-12, środa, czwartek 
16-18) i listownie po otrzymaniu 
koperty zwrotnej. 

K-128 


Naprawa komputerów 

Perzynski Waiszawa 24-93-91 

D-74 


COMPUTER- 

SERVICE 

MS elektronik 
naprawy komputerów 
Spectrum 48k, + , 128, +2, 
+3 

Amstrad- Schneider 
Sharp 

Drukarki, Interfejsy 
Wyjścia monitorowe 
Czynne od 9 00—16 00 
MSelektronik Legionowa 23, 
00 343 Warszawa 
Dojazd 105 305, F (jelonki) 
tel. 37-76-65 

(K-118) 


TURBO 2000 

System transmisji danych dla ATARI 

— 7 razy szybciej 

— 7 krotna oszczędność taśmy 

— niezawodność pracy 

— pełna automatyka działania 

— bogata biblioteka programów 

To nowy standard w Polsce — kup 
nie zwlekaj! 

„STUDENT — SERV!CE” 42-200 
Częstochowa 

ul Zawadzkiego 29, tel 573—75 

_ K-141 

ATARI, programy na dyskiet¬ 
kach, napisz-otrzymasz boga¬ 
tą ofertę ATARICA, skr 46 
82-300 Elbląg 

G 82 


Programy na Atari Tamo! Robert Hysa 

ul. Miła 10/19 41-250 Czeladź 

G-73 

Naprawa komputerów ATARI, 
MODORE IBM SPECTRUM 

COM- 

oraz 

urządzeń peryferyjnych. Warszawa tek 

22-07 85 

D-84 



— ponad 1500 programów 

— na kasetach i dyskietkach 

— co piąty program gratis 

— gwarancja jakości 

— rachunki 

— katalogi bezpłatnie 
ART SOFTWARE 
66-542 Zwierzyn P-1 

(D 46) 


OTV RADZIECKIE 
JUNOST ELEKTRONIKA SILELIS 
oraz STACJONARE 
NAPRAWA • KINESKOPY # 
DEKODERY PAL • FONIA CCIR 
WEJŚCIA MONITOROWE 
INTER SERWIS, 
ul. Rutkowskiego 10/12 

00-020 Warszawa, tel 27-47-72 

D 76 


ZX Spectrum 

Ekspresowe naprawy klawiatur 
NiKUE ul Meissnera 14 m 1, 
03-982 Warszawa tel. 15-93-38 
wieczorem 

D 73 


Innowacyjno-Wdrożeniowe Towarzystwo Techniczne 



poleca profesjonalne oprogramowanie. 

— system „Karta Drogowa” 
kompleksowe rozliczenie bazy transportowej, 

— system „Kadry” i „Płace” 

Ponadto oferujemy kompletację i dostawę sprzętu 
niezbędnego do funkcjonowania w/w systemów 
Komputery wyłącznie renomowanych firm zachod¬ 
nioeuropejskich. Niskie ceny. Natychmiastowa do¬ 
stawa. Zapewniamy dostawy materiałów eksploata¬ 
cyjnych (papier, taśmy itp.) 

Nasz adres: 

Tarnobrzeg 39-400 
ul. M Kopernika 28 
tek 22-11-01 tlx. 062 404 
skr. poczt — 141 

K 84 


BAJTEK 7/89 29 






































SPRZĘŻENIE ZWROTNE 


(ta druga jest dopiero przygotowywana do 
druku) Znajdziesz tam odpowiedzi na wsę 

kszość nurtujących C ę pytań. 


1. Czy jest możliwa komunikacja A ta 
ri z IBM za pomocą dyskietki? 

2. Jak można używać CP/M na Atari? 
Jakie przeróbki są konieczne , aby było 
to możliwe? 

Jerzy Ratajczak 
Warszawa 

1 Podobnie tak. Istnieje program kopiu¬ 
jący pliki tekstowe zapisane w formacie 
Atari na format IBM i odwrotnie. Wymaga 
on jednak bardzo specyficznego sformato¬ 
wania dyskietki przez IBM i — jak dotych¬ 
czas — w redakcji me udało nam się tego 
dokonać 

2 Jedynym znanym mi sposobem uży¬ 
cia CP/M na Atari jest wykorzystanie spec¬ 
jalnej przystawki ATR 8000 Była ona pro¬ 
dukowana w USA lecz nie wiem, czy jesz¬ 
cze można ją nabyć, gdyż przestała się po¬ 
jawiać w ofertach publikowanych w zachod¬ 
nich czasopismach CP/M jest systemem 
przeznaczonym dla procesora Z80 Nie 
można w ęc wykonać w komputerze prze¬ 
róbek umożliwiających korzystanie z mego 
(chyba ze przerobie Atari na Amstrada 
CPC-6128 albo Commodore 128) 


F- ; 

do odczytania. Z ilu bajtów składa się 
rekord? Czy trzeba dopełnić ostatni re¬ 
kord zerami, gdy jest on niepełny? 

3. W „ Bajtku ” 2/89 podano , że funkcja 
USR zwraca zawartość komorek 203 i 
204, natomiast w „Atari Basic” wymie¬ 
nione są komorki 212 i 213. Co jest pra¬ 
wdą? 

Karol Egeman 
Częstochowa 


1 Instrukcja GRAPHICS w pełni odpo¬ 
wiada instrukcji OPEN 6,A,B,S: ”, gdzie A i 
B są parametrami wybieranego trybu grafi¬ 
cznego. W języku maszynowym trzeba 
więc użyć procedury otwierającej kanał 
iOCB, czyli zastępującej odpowiednią in¬ 
strukcję OPEN 

2. Standardowy rekord zapisu na taśmie 
składa się zawsze ze 128 bajtów. Jeśli 
ostatni rekord jest niepełny, to zostaje auto¬ 
matycznie uzupełniony zerami Ponadto na 
końcu jest transmitowany specjalny rekord 
wskazujący zakończenie pliku Sposob 
transmisji może zostać zmieniony przez in¬ 
gerencję w system operacyjny komputera 

3 W „Bajtku” nastąpiła pomyłka. Wynik 
funkcji USR jest pobierany z komórek 212 i 
213 


W wielu programach zaobserwowa¬ 
łem płynne przesuwanie się tekstu w 
poziomie. Jak można uzyskać taki efekt 
na Atari Basicu lub Turbo Basicu? 

Grzegorz Kępiński 
Warszawa 

Zadowalający efekt płynnego przesuwa¬ 
nia tekstu można uzyskać wyłącznie przy 
pomocy języka maszynowego. Zwykie wy¬ 
korzystuje się przy tym przerwania VBLKI 
lub T1MER2 Użycie w tym celu dowolnego 
interpretera Basica nie da zadowalającego 
wyniku gdyż napis będzie przesuwany bar¬ 
dzo wolno, a ponadto program me może 
wtedy wykonywać innych czynności. Oczy¬ 
wiście procedurę przerwania można dołą 
czyc do programu w Basicu. 


1. Jak zrealizować instrukcję GRAP¬ 
HICS z poziomu języka maszynowego? 

2. W drugim bajcie programu typu 
„boot tape” podana jest liczba rekordów 


1. Podczas pisania programów w Ac- 
tion!, po naciśnięciu RESET komputer 
przechodzi do DOS-u. Powoduje to utra¬ 
tę programu. Czy jest na to jakaś rada? 

2. Od jakiego adresu zaczyna się edy¬ 
tor Actionl? 

3. Co oznaczają nawiasy trójkątne w 
katalogu plików dyskowych? 

4. Jak można odczytać wartość licz¬ 
nika PC? 

Roland Zimek 
Opole 

1/2. Oryginalny system Action 1 jest 
umieszczony na cartridge u, który zajmuje 
obszar od adresu 40960 (sAOOO) do 49151 
(sBFFF), i jest odporny na RESET Zauwa¬ 
żona wada wynika z użytkowania pirackiej 
kopii systemu 

3 Nawiasy trójkątne oznaczają plik* któ¬ 
re są niedostępne dla DOS 2 0, czyli prze¬ 
kraczają pojedyńczą gęstosc zapisu Ozna 
czenie to zostało wprowadzone po opraco¬ 
waniu DOS 2 5 który zastąpił DOS 2.0. 

4 Stan licznika programu PC me można 
odczytać. 







Wojewódzkie Przedsiębiorstwo 
Handlu Wewnętrznego 
Oddział w Tychach 

VIDEOBIT 

43-100 Tychy, AI.ZMP 77 
tel.276975 

poleca między innymi 

— sprzęt komputerowy 

Atari • Commodore • Amstrad • 

• IBM PC XT/AT/PS 2 

— drukarki STAR, EPSON, AMSTRAD 

— Sprzęt audiowizualny 

— magnetowidy 

— OTV PAL/SECAM 

— Videoskopy 

— kamery 

— anteny satelitarne 

— aparaturę badawczo-naukową 

Udzielamy gwarancji, prowadzimy naprawy po¬ 
gwarancyjne. Zapewniamy o atrakcyjnych ce¬ 
nach. 



(SB 18) 




• Wystawa literatury i oprogramowania firm: 
Microsoft, Ashtona Tad, Osborne i innych 

• Wystawa wydawnictw: Data Baker, Chip, 
Mark-Technik, Komputer i Bajtek. 

• Udział w br. wielu firm zagranicznych i kra¬ 
jowych. 

• Wyprzedaż z dużą bonifikatą artykułów wy¬ 
stawienniczych za złotówki i walutę. 

Wśród zwiedzających nagrody: video, telewi¬ 
zory kolorowe, literatura, wycieczki zagranicz¬ 
ne, w tym do ZSRR na podobne targi w Mosk¬ 
wie w dniach 10—20 listopada br. oraz targi 
CEBIT w Hanowerze 1990 roku. 

Zapraszamy 

Prosimy wyciąć 8 przesłać na adres organizatora, 
kupony wezmą udział w losowaniu nagród. 


Prosimy o rezerwację . szt. bile¬ 

tów (1 szt. — 1500 zł) 

Prosimy o rezerwację hotelu. 

ilość osób 

Adres zakładu (osoby).... 


miejscowość.... 
tel.tlx 


(SB 45) 
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TYLKO DLA PRZEDSZKOLAKÓW 


Cześć Maluchy! 

Przyszedł do Was z wizytą 
kolega. Nie należy — jak Wy — 
do Komputerowych Przedszko¬ 
laków, a więc komputer jest dla 
niego urządzeniem egzotycz¬ 
nym i nieco tajemniczym. Po 
wypróbowaniu kilku gier kole¬ 
ga odkłada drążek sterowy i 
pyta: „Czy mógłbyś mi poka¬ 
zać, na czym polega to progra¬ 
mowanie?” 

W tym momencie stajesz przed poważnym pro¬ 
blemem. Jak w ciągu kilkunastu minut przedstawić 

zasadę programowania? Warto by było napisać tak¬ 
że jakiś prosty program Zwykle taki pokaz kończy 
się na stworzeniu czegoś podobnego do tego: 

10 PRIN ' „Jurek-Ogorek, kiełbasa i sznurek” 

20 PRINT 
30 PRINT 
40 GOTO 10 

(Oczywiście jeśli nasz kolega ma na imię Jerzy ) 
Trzeba przyznać — faktycznie — można naz¬ 
wać to programem i to napisanym jedynie przy po¬ 
mocy dwóch instrukcji. Kolega stwierdza, ze pro¬ 
gramowanie jest zajęciem fascynującym, ale praw¬ 
dę mówiąc minę ma nieco zawiedzioną A może da 
się wymyślić cos ciekawszego i równie prostego 9 
Właśnie cos takiego chciałem Wam zaproponować. 
Będą to wyścigi samochodowe napisane przy po¬ 
mocy tyiko jednej instrukcji (PRINT) Rozpocznie¬ 
my od zaprogramowania samochodu wyścigowe¬ 
go 


110 PRINT " 

120 PRINT " 

130 PRINT ■ 

140 PRINT M 
150 PRINT ■ 

160 PRINT " 

170 PRINT - 
RUN 

o-A-n 

/ i \ 
:/+\: 
Po'! 

()-< U >-() 
\J 


{}-/ \-{} B 
/ 1 \" 

:mi" 

I i d ! I " 

()-< U >-()" 

\./" 

>ENTER/RETUF.N< 


Ręsdy 


No dobrze mamy samochód, ale on stoi w miej¬ 
scu. Poruszymy go również przy pomocy instrukcji 
PRINT Uzupełnimy nasz program o następujące li¬ 
nie: 


101 PRINT; PRINT: PRINT; PRINT: PRINT 

102 PRINT: PRINT: PRINT: PRINT: PRINT 

103 PRINT: PRINT: PRINT: PRINT: PRINT 

104 PRINT: PRINT: PRINT: PRINT: FFINT 

105 PRINT: PRINT: PRINT: PRINT: PRINT 

171 PRINT: PRINT: PRINT: PRINT: PRINT 

172 PRINT: PRINT: PFINT: PRINT: PRINT 

173 FRINT: PRINT: PRINT: PRINT: PRINT 

174 PRINT; PRINT: PRINT: PRINT: FRINT 

175 PRINT: PRINT; PFINT: PRINT: PRINT 


Ruszył naprawdę Najpierw wszystkie napisy 
uciekły do góry, a następnie zza dolnej krawędzi 
ekranu wyskoczył nasz samochód, przejechał 
przez cały ekran i zniknął za jego górną krawędzią 
Wykorzystaliśmy tutaj zjawisko tak zwanego , prze¬ 
wijania ekranu, czyli przesuwania wszystkiego, co 
znajduje się na ekranie do góry w momencie, gdy 
kolejna lima me mieści s ę na ekranie W przypadku 
komputera ZX Spectrum i jego licznej rodzinki 
sprawa troszeczkę się komplikuje. Otóż Spectrum 
po zapełnieniu całego ekranu zatrzymuje program i 
czeka na naciśnięcie dowolnego klawisza Można 
tego umknąć wpisując po uruchomieniu kompute¬ 
ra. 

POKE 23692 255 REM *** Tyiko Spectrum *** 
Oczywiście należy to zrobić tak, aby me widział 
tego nasz kolega, bo mu się znowu wszystko po¬ 
miesza w głowie 

Ale co to za wyścigi skoro mamy tylko jeden sa¬ 
mochód? Czym prędzej musimy nadrobić to kary¬ 
godne zaniedbanie Oto program rysujący i urucha¬ 
miający kolejne samochody 


:io FRINT * x* 

220 f FINT n #!-/ \-i# B 
130 FRINT K b 2 o n 

240 PFINT !1 //-W 
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FRINT 
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K 

\./“ 



271 

PFINT: 

PRINT 

• PRINT: 

PRINT: 

FRINT 

~7~ 

FRINT 

FRINT 

* FRINT: 

PRINT: 

FRINT 

310 
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320 

FRINT 
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FRINT 
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FRINT 
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370 

PRINT 
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371 

PRINT: 

FRINT 

: FRINT: 

PRINT: 

FRINT 

410 

FFINT 
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420 

PRINT 
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430 

PRINT 

» 1 
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440 

FRINT 
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FRINT 
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FRINT 
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470 

FRINT 

n 
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471 

PRINT: 

FRINT 

: FRINT: 

FRINT: 

FRINT 

472 

FRINT: 

FRINT 

: FRINT: 

FFINT: 

FRINT 

473 

FFINT: 

FRINT 

: FRINT: 

FRINT: 

FRINT 

474 

PFINT: 

FRINT 

: FRINT: 

PRINT: 

FRINT 

473 

FRINT: 

PRINT 

: FRINT: 

FRINT: 

PRINT 


Przy okazji usuńmy linie 173, 174 i 175 Wpisując 
numer linii i naciskając >ENTER/RETUR!\k Zmniej¬ 
szy to dystans pomiędzy pierwszym samochodem 
a następnymi 

Pisząc cały ten program skorzystaliśmy dotych¬ 
czas tylko z jednej instrukcji — instrukcji PRINT 
Musicie przyznać, ze efekt jest interesujący Nie¬ 
stety program wykonuje się bardzo szybko i trzeba 
go uruchamiać od nowa. Są na to dwie rady. Po 
pierwsze można dopisywać do programu kolejne 
samochody a po drugie można wprowadzić nową 
instrukcję. Łatwiejsze będzie z pewnością to drugie 
rozwiązanie, tym bardziej, ze ta „nowa instrukcja' 
me jest wcale dla nas (a nawet dla Waszego kolegi) 
nowa. Chodzi tu oczywiście o rozkaz RUN Przy- 
zwycza iliśmy się korzystać z mego wyłącznie do 
uruchamiania programu, a tymczasem może on 
byc z powodzeniem wykorzystywany w treści pro¬ 
gramu. 

Dopiszmy więc ostatnią Imię 
!0C RUN 


Teraz nasz program będzie biegał w kołko, az 
mu me przerwiemy lub me wyłączymy komputera 
Szerokiej drogi i gumowych drzew zyczy Wam 

Romek 
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